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DESCRIPTION 

RECORDING MEDIUM, PLAYBACK DEVICE, RECORDING METHOD, 
PLAYBACK METHOD, AND COMPUTER PROGRAM 

5 TECHNICAL FIELD 

The present invention relates to recording media such 
as BD-ROMs for distributing movie works and playback devices 
for playing such recording media, and in particular to 
improving the way in which movie works that realize dynamic 
10 playback controls are provided. 

BACKGROUND ART 

With the retail of DVD-ROMs and BD-ROMs, the greater 
the number of variations of a movie work (title) that can 

15 be sold on a single disk, the greater the added value of the 
product. Scenario data called static scenarios and dynamic 
scenarios plays a positive role in increasing the number of 
title variations. A static scenario is information showing 
a playback path defined in advance by a disk creator. In 

20 comparison, a dynamic scenario is a scenario that dynamically 
changes the progress of playback according to a status 
setting of the device. 

Figs.lA-lC show a dynamic scenario. The dynamic 
scenario realizes a "language credit" for switching playback 

25 scenes according to a language setting in the playback device. 
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In Figs . 1A-1C, ^PL" is short for PlayList, which is a playback 
path, and W PI" is short for Playltem, which is a playback 
section. The dynamic scenario in Figs . 1A-1C realizes 
conditional playback such that if the language setting 
5 (SPRM(O)) in the playback device is "Japanese" (i.e. 
"if (SPRM(O) )== Japanese") , playback section PI#1 of playback 
path PL#4 (PL#4, PI#1) is played, and if the language setting 
in the playback device is other than PL#4 (i.e. "else"), 
playback section PI#1 of playback path PL#2 (PL#2, PI#1) is 

10 played. As a result of this conditional playback, playback 
is performed via playback paths that differ depending on the 
language setting made by the user. The arrows hbl and hb2 
in Fig. IB symbolically show the conditional branching that 
results from a dynamic scenario. The prior art relating to 

15 DVD playback controls includes the known technology 
disclosed in Japanese patent application no. 2856363. 

However, if the user conducts a menu call while the 
playback device is executing a playback control in accordance 
with an internal status setting, there is a danger that the 

20 status setting of the playback device will be altered. A menu 
call is an on-demand type branch for branching to a 
status-setting routine in the playback device triggered by 
the user depressing a menu key. Being a call rather than a 
jump, the menu call follows processing (1) for saving a value 

25 held in a register of the playback device prior to the 
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execution of the status-setting routine, and follows 
processing (2) for restoring the saved value to the register 
after the execution of the status-setting routine. 
Register-held values that are saved and restored show the 
5 current point in time of playback. As such, even if the user 
requests a menu call in the middle of a playback path, thereby 
initiating a status-setting routine, playback is resumed 
from immediately after the previous playback position once 
the status-setting routine has ended. 

10 In the example given here, the language setting in the 

playback device is English, and the playback time in 
Figs.lA-lG is over PL#2, which is the playback path 
specifically for English. If a menu call is conducted in the 
above state and the status setting in the playback device 

15 is updated from English to Japanese, the playback device 
loses the position for resuming playback. This is because 
it does not make sense to resume playback on the English 
language playback path when the language setting has changed 
from English to Japanese as a result of the menu call. Also, 

20 the setting of a meaningless playback position risks inviting 
a hang up when software is implemented in the playback device . 

These difficulties can be avoided by uniformly 
prohibiting menu calls. However, when a number of versions 
of a movie work are recorded on a single optical disk, it 

25 is fully conceivable that a title that does not execute 
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language credits is recorded on the optical disk. Uniformly 
preventing menu calls during the playback of titles shows 
a lack of consideration to the user. 

An object of the present invention is to provide a 
5 recording medium capable of executing menu calls in response 
to the particular characteristics of individual titles when 
different versions of a movie work are recorded on a single 
recording medium. 

10 DISCLOSURE OF THE INVENTION 

A recording medium provided to achieve the above object 
has video data and a dynamic scenario recorded thereon, the 
dynamic scenario being a command string showing a playback 
control procedure of the video data and having attribute 

15 information appended thereto, the attribute information 
showing a control procedure for when a user requests a menu 
call during playback of the video data and including a first 
flag, and the first flag indicating, when the menu call ends 
during playback of the video data, whether to resume playback 

20 of the video data from the playback position at the time that 
the menu call was requested. 

According to this structure, control procedures 
relating to menu calls are set at a dynamic scenario level, 
which is the highest layer in a layer model comprising, from 

25 bottom to top, streams, playback paths , and dynamic scenarios . 
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When a title that the creator particularly wants to create 
realizes a language credit, controls can be performed to 
accept requests for menu calls without resuming playback. 
As a result, titles can be easily divided into two types even 
5 when the streams and playback paths are the same; namely, 
titles with respect to which menu calls are permitted, and 
titles with respect to which menu calls are prohibited. With 
the creation of titles, the number of variations having 
different control procedures can be increased with little 

10 effort, since there is no increase the number of playback 
paths or streams. 

Japanese patent application no. 2856363 discloses 
technology for setting the permissibility of user operations 
based on stream levels and playback paths. According to the 

15 disclosed technology, dividing titles into those with 
respect to which menu calls are either permitted or 
prohibited would result in an indiscriminate increase the 
number of streams and playback paths because of the 
permissibility of user operations being set based on stream 

20 levels and playback paths. In contrast, with the present 
invention, there is no increase in the number of streams and 
playback paths, because the permissibility of playback 
resumption after completion of a menu call is set at a dynamic 
scenario level. Since there is little if any increase in the 

25 number of streams and playback paths, it is possible 
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according the present invention to prevent errors such as 
titles with respect to which menu calls should be permitted 
being confused with titles with respect to which menu calls 
are prohibited. 

5 

BRIEF DESCRIPTION OF THE DRAWINGS 

Figs.lA-lC show a dynamic scenario; 

Fig. 2 shows a usage application of a recording medium 
pertaining to the present invention; 
10 Fig. 3 shows a structure of a BD-ROM; 

Fig. 4 represents an application format of a BD-ROM using a 

directory structure ; 
Fig. 5 is a classification diagram showing the files in Fig. 4 
classified in terms of functionality; 
15 Fig. 6 shows a layer model that targets a BD-ROM; 

Fig. 7 schematically shows how an AV clip is structured; 
Fig. 8 shows an internal structure of Clip information; 
Fig. 9 shows an internal structure of PL information; 
Fig. 10 schematizes indirect referencing using PL 
20 information; 

Fig. 11 shows an example of a different piece of PL information 
(PLinfo#2) to that (PLinfo#l) in Fig . 10 being defined; 
Fig . 12 shows playback modes at a fourth layer in a layer model; 
Fig. 13 shows an internal structure of a MOVIE object; 
25 Figs.l4A shows a dynamic scenario having 

6 
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resume_intension_f lag, me nu_c a 1 l_ma s k , and 

Title_search_mask appended thereto; 
Fig.l4B shows a playback control based on the MOVIE object 
in Fig.l4A; 

5 Fig.l4C shows playback being restarted from the head of a 
title; 

Fig.l5A~15C show processing on the side of the playback 

device to initiate restarting of playback; 
Figs.l6A-16C show a descriptive example of a MOVIE object 
10 when branching that results from a question is 

realized; 

Figs . 17A-17C show a descriptive example of a dynamic scenario 

when indicating a parental lock; 
Figs . 18A-18b show an exemplary setting of the 
15 Title_search_mask; 

Fig. 19 shows an internal structure of a playback device 

pertaining to the present invention; 
Fig. 20 is a flowchart showing processing procedures 
performed by a module manager 20; 
20 Fig. '21 is a flowchart showing processing procedures 
performed by module manager 20; 
Fig. 22 is a flowchart showing processing procedures 

performed by module manager 20; 
Fig.23A-23C show an internal structure of INFO.BD; 
25 Fig.2 4A shows a BD-ROM having a plurality of dynamic 

7 
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scenarios (001. MOVIE, 002. MOVIE, 003. MOVIE, 

001. CLASS, 002. CLASS, 003. CLASS, ) recorded thereon; 
Fig.24B shows a descriptive example of an Index Table when 

the dynamic scenarios shown in Fig.24A are listed; 
5 Fig . 25A shows indirect referencing in a full system when the 

Index Table is as shown in Fig. 2433; 
Fig.25B shows indirect referencing in a core system; 
Fig. 2 6 schematically shows how branching from a MOVIE object 

to a Java object is performed; 
10 Fig. 27 shows how branching is performed when a BD-ROM having 

the scenario in Fig. 18 recorded thereon is mounted in 

a core-system playback device; 
Fig. 28 shows processing procedures performed by module 

manager 2 0 in an embodiment 2; 
15 Fig . 2 9A shows a BD-ROM having a plurality of Index Tables 

for different versions recorded thereon; 
Fig . 29B assumes the BD-ROM in Fig.2 9A being mounted in a 

version 0.1 playback device; 
Fig.2 9C assumes the BD-ROM in Fig.29A being mounted in a 
20 version 1.1 playback device; 

Fig. 30 is a flowchart showing processing procedures 

performed by module manager 20; 
Fig. 31 shows a menu hierarchy realized by a BD-ROM; 
Fig. 32 shows MOVIE objects for operating menus having a 
25 hierarchy; 
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Fig- 33 is a flowchart showing branch-control processing 
procedures ; 

Fig. 34 shows an internal structure of a Playltem pertaining 

to an embodiment 5; 
Fig. 35 shows a hierarchical structure of a PlayList with 

respect to which playback controls are performed by 

MOVIE and Java objects; 
Fig. 36 shows how filter specifications are performed as a 

result of Playable_PID_entries in Playltems #3 and #12; 
Fig. 37 shows how playback output is made possible by 

Playable_PID_entries in Playltems #3 and #12; 
Fig. 38 is a flowchart showing PLPlay function execution 

procedures performed by a playback control engine 12; 

and 

Fig. 39 is a flowchart showing production processes for a 
BD-ROM. 

BEST MODE FOR CARRYING OUT THE INVENTION 

Embodiment 1 

An embodiment of a recording medium pertaining to the 
present invention is described below. Firstly, a usage act 
is described in relation to the implementation of a recording 
medium pertaining to the present invention. Fig. 2 shows a 
usage act of a recording medium pertaining to the present 
invention. BD-ROM 100 in Fig. 2 is a recording medium 

9 
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pertaining to the present invention. BD-ROM 100 is used to 
supply movie works in a home theater system formed from a 
playback device 200, a television 300, and a remote 
controller 400. 

5 Next, a production act is described in relation to the 

implementation of a recording medium pertaining to the 
present invention. A recording medium pertaining to the 
present invention can be implemented as a . result of 
enhancements in the application layer of BD-ROMs . Fig. 3 shows 

10 the structure of a BD-ROM. 

Level 4 in Fig. 3 shows a BD-ROM, and the third level 
shows a track on the BD-ROM. The track at level 3 depicts, 
in a laterally drawn-out form, the tracks spiraling from the 
inside to the outside of the BD-ROM. These tracks are formed 

15 from a lead-in area, a volume area, and a lead-out area. The 
volume area in Fig . 3 has a layer model consisting of a physical 
layer, a filesystem layer, and an application layer. A 
recording medium pertaining to the present invention is 
industrially manufactured by forming the data format shown 

20 in Fig. 3 on the application layer of a BD-ROM. 

Fig. 4 expresses an application layer format 
(hereinafter, simply "application format") of a BD-ROM using 
a directory structure. As shown in Fig. 4, below a ROOT 
directory in the BD-ROM is a BDMV directory, and below the 

25 BDMV directory is a JCLASS directory and a BROWSER directory. 
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Subordinate to the BDMV directory exist the following files: 
INFO.BD, XXX.M2TS, XXX.CLPI, YYY.MPLS, and ZZZ. MOVIE. 
Subordinate to the JCLASS directory is disposed ZZZ. CLASS, 
and subordinate to the BROWSER directory is disposed ZZZ . HTM. 
5 Fig. 5 is a classification diagram of when these files 

are classified from a functionality viewpoint. In Fig. 5, the 
hierarchy formed from the first, second, third and fourth 
layers symbolically shows the classifications in the diagram. 
In Fig. 5, XXX.M2TS is grouped in the second layer. XXX.CLPI 

10 and YYY.MPLS are grouped in the third layer (static 
scenarios). ZZZ. MOVIE, which is subordinate to the BDMV 
directory, ZZZ. CLASS, which is subordinate to the JCLASS 
directory, and ZZZ. HTM, which is subordinate to the BROWSER 
directory, are grouped in the fourth layer. 

15 The classifications in Fig. 5 (first to fourth layers) 

target a layer model such as shown in Fig. 6. A layer model 
in control software that targets a BD-ROM is described below 
while referring to Fig. 6. 

The first layer in Fig. 6 is a physical layer in which 

20 supply controls relating to streams targeted for processing 
are implemented. As shown in the first layer, target streams 
have as their supply source not only BD-ROMs but also HDDs 
(hard disk drives) , memory cards, networks and other kinds 
of recording and communication media . Controls (disk access, 

25 card access, network communication) directed towards these 
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HDDs, memory cards, and networks are implemented on the first 
layer . 

The second layer is a decoding format layer. This second 
layer is where the decoding format used in decoding streams 

5 supplied by the first layer is defined. The MPEG-2 decoding 
format is employed in the present embodiment. 

The third layer (static scenarios) defines the static 
scenarios of streams. Static scenarios are playback path 
information and Clip information defined in advance by the 

10 disk creator, the third layer (static scenarios) being where 
playback controls based on these static scenarios are 
defined. 

The fourth layer is for realizing dynamic scenarios in 
streams. Dynamic scenarios are scenarios for dynamically 
15 changing the progress of playback as a result of user 
operations, the device status, and the like, the fourth layer 
being where playback controls based on these dynamic 
scenarios are defined. Files relating to streams, static 
scenarios, and dynamic scenarios are described below in 
20 accordance with this layer model. 

Firstly, an AVClip (XXX.M2TS) belonging to the second 
layer is described. 

AVClip (XXX.M2TS) is an MPEG-TS (transport stream) 
format digital stream obtained by multiplexing a video stream, 
25 one or more audio streams, and one or more graphics streams, 

12 
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being presentation graphics streams and interactive graphics 
streams. Video streams show the moving image portions of a 
movie, audio streams show the audio portions of a movie, 
presentation graphics streams show the subtitles of a movie, 
5 and interactive graphics streams show procedures involved 
in dynamic playback controls that target menus. Fig. 7 
schematically shows how an AVClip is constituted. 

An AVClip (4 th level) is formed by converting a video 
stream comprising a plurality of video frames (pictures pjl, 

10 pj2, pj3) and an audio stream comprising a plurality of audio 
frames (1 st level) into a PES packet string (2 nd level) , which 
is then converted to TS packets (3 rd level) . Likewise, a 
subtitle-related presentation graphics stream and a 
dialogue-related interactive graphics stream (7 th level) are 

15 converted to a PES packet string (6 th level), which is 
converted to TS packets (5 th level) , and the TS packets are 
then multiplexed. The multiplexing involves arranging TS 
packets storing video frames and TS packets storing audio 
frames so that audio frames are positioned close to video 

20 frames that are to be read from the BD-ROM at the same time 
as the audio frames. 

AVClips generated though the above process are 
portioned into a plurality of extents and recorded in an area 
of a BD-ROM, as is the case with normal computer programs. 

25 An AVClip comprises one or more ACCESS UNITs, and can be cued 
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in these ACCESS UNITs . An ACCESS UNIT is the smallest decoding 
unit that includes a single GOP (group of pictures) and audio 
frames to be read at the same time as the GOP. GOPs include 
bi-directionally predictive (B) pictures, which are 
5 compressed using time-correlation characteristics with 
images to be played in a past direction and a future direction, 
predictive (P) pictures, which are compressed using 
time-correlation characteristics with images to be played 
in a past direction, and intra (I) pictures, which are 

10 compressed using frequency-correlation characteristics (i.e. 
not time-correlation characteristics) in the images of 
individual frames . 

Moreover, the filename "XXX" in XXX.M2TS abstracts the 
3-digit identification number appended to the AVClip in the 

15 BD-ROM. That is, the AVClip in Fig. 7 is uniquely identified 
using the "XXX" . Thus completes the description of the stream 
(XXX.M2TS) . It should be noted that the 3-digit number 
referred to here is merely exemplary, and may be any length. 

20 Static Scenarios 

Static scenarios files (XXX.CLPI, YYY.MPLS) are 
described below. 

Clip information (XXX.CLPI) is management information 
relating to individual AVClips . Fig. 8 shows an internal 
25 structure of Clip information. AVClips are obtained by 

14 



WO 2004/074976 



PCT/JP2004/002026 



multiplexing video and audio streams, and since AVClips can 
be cued in ACCESS UNITs, management items of the Clip 
information include the attributes of the video and audio 
streams and where the cue positions are in the AVClips. The 
5 leaders in Fig. 8 highlight the Clip information structure. 
As shown by the leader hnl, Clip information (XXX.CPLI) 
comprises "attribute information" relating to video and 
audio streams and "EP_map", which is reference table for 
cueing ACCESS UNITs. 

10 Attribute information (Attribute), as shown by the 

leader hn2 , comprises attribute information relating to a 
video stream (Video attribute information) , an attribute 
information number (Number) , and attribute information 
relating to each of a plurality of audio streams multiplexed 

15 on the AVClip (Audio attribute information #l-#m) . The Video 
attribute information, as shown by the leader hn3, indicates 
the compression format used to compress the video stream 
(Coding) , and the resolution (Resolution) , aspect ratio 
(Aspect) and frame rate (Framerate) of individual pieces of 

20 picture data structuring the video stream. 

On the other hand, Audio attribute information #l-#m 
relating to the audio stream, as shown by the leader hn4, 
indicates the compression format used to compress the 
respective audio streams (Coding) , and the channel number 

25 (Ch.) and corresponding language (Lang.) of respective audio 
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streams . 

EP_map is a reference table for referring indirectly 
to the addresses of a plurality of cue positions using time 
information, and, as shown by the leader hn5, comprises 
5 plural pieces of entry information (ACCESS UNIT#1 entry, 
ACCESS UNIT#2 entry, ACCESS UNIT#3 entry, ...) and an entry 
number (Number) . Each entry, as shown by the leader hn6, 
indicates a playback start time of a corresponding ACCESS 
UNIT in correspondence with an address and the size (I-size) 
10 of the head I-picture in the ACCESS UNIT. The playback start 
time of an ACCESS UNIT is expressed as a timestamp 
(presentation timestamp) of picture data positioned at the 
head of the ACCESS UNIT. Also, the addresses in the ACCESS 
UNITs are expressed by the serial numbers of TS packets 
15 (Source Packet Number or "SPN") . Since a variable-length 
coding compression format is employed, it is possible to cue 
from an arbitrary playback time to a piece of picture data 
in an ACCESS UNIT corresponding to the playback time by 
referring to the entry of the ACCESS UNIT, even when sizes 
20 and playback times of ACCESS UNITs that include GOPs are not 
uniform. Moreover, the filename "XXX" of XXX.CPLI uses the 
same name as the AVClip to which the Clip information 
corresponds. In other words, the filename of the Clip 
information in Fig. 8, being "XXX", corresponds to AVClip 
25 (XXX.M2TS) . Thus concludes the description of Clip 
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information. Playlist information is described next. 

YYY.MPLS (PlayList information) is a table structuring 
a PlayList, which is playback path information, and comprises 
plural pieces of Playltem information (Playltem information 
5 #1, #2, #3, #n) , and a Playltem information number (Number) . 
Fig. 9 shows an internal structure of PL information. Playltem 
information is pointer information that defines one or more 
playback logical sections structuring a PlayList. The 
structure of Playltem information is highlighted by the 

10 leader hsl. Playltem information is, as shown by the leader 
hsl, structured from a "Clip_inf ormation_f ilename" 
indicating the filename of playback section information 
relating to an AVClip to which the In-point and Out-point 
of a playback section belong, a "Clip__codec_identif ier" 

15 showing the encoding format used to encode the AVClip, an 
"In_time", which is time information showing the start of 
a playback section, and an "Out_time" , which is time 
information showing the end of a playback section. 

A characteristic of Playltem information is the 

20 notation. That is, playback sections are defined by an 
indirect referencing format that uses an EP_map as a 
reference table. Fig. 10 schematizes indirect referencing 
using PL information. The AVClip in Fig. 10 is structured from 
a plurality of ACCESS UNITs . The EP_map in the Clip 

25 information specifies the sector addresses of the ACCESS 
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UNITs, as shown by the arrows ayl, ay2, ay3 and ay4 . Arrows 
jyl, jy2, jy3 and jy4 in Fig. 10 schematically show the 
referencing of ACCESS UNITs using Playltem information. In 
other words, this shows that referencing by Playltem 
5 information ('jyl, jy2, jy3, jy4) involves indirect 
referencing in which the addresses of ACCESS UNITs included 
in the AVClip are specified via the EP_map. 

Playback sections on BD-ROM formed from groupings of 
Playltem information, Clip information and AVClips are 
10 called "Playltems" . Playback units on a BD-ROM that are 
formed from groupings of PL information, Clip information 
and AVClips are called "PlayLists" (abbreviated as "PL") . 
Movie works recorded on a BD-ROM are structured in these 
logical playback units (PLs) . Since movie works on a BD-ROM 
15 are structured in logical playback units, it is possible to 
easily create, as distinct from the main movie work, movie 
works from scenes in which only certain characters appear, 
for instance, by defining the PLs specifying these scenes. 
Fig. 11 shows an example of when a different PL (PL information 
20 #2) to the PL (PL information #1) shown in Fig. 10 is defined. 

The greatest merit of static scenarios is being able 
to increase the range of a moviemaker' s expression, since 
the variations of a movie work increase simply by defining 
different pieces of PL information. 
25 There are, in addition to PLs and Playltems, playback 



WO 2004/074976 



PCT/JP2004/002026 



units in BD-ROM called Chapters . Chapters are structured from 
one, two, or more Playltems . 

Also, the filename n YYY" of PL information abstracts 
the 3-digit identification number appended to PL information 
5 in BD-ROM. That is, the PL information in Fig. 11 is uniquely 
identified using the identification number YYY. Expressing 
the identification number of PL information as "YYY" shows 
that this identification number is a different numbering 
system to the identification number XXX of the AVClip and 
10 Clip information (the 3-digit number us.ed here is merely 
exemplary, and may be any number of digits) . 

Thus concludes the description of static scenarios. 
Dynamic scenarios are described next. 



15 Dynamic Scenarios 

Dynamic scenarios are command strings showing dynamic 
playback control procedures relating to AVClips. Dynamic 
playback control procedures change in response to user 
operations with respect to a device, and are similar to 

20 computer programs in character. Here, dynamic playback 
controls have two modes. One of the two modes is for playing 
video data recorded on BD-ROM (normal mode) and the other 
mode is for enhancing the added value of video data recorded 
on BD-ROM (enhanced mode) in a playback environment specific 

25 to AV devices . Fig . 12 shows playback modes on the fourth layer 
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of the layer model. One normal mode and two enhanced modes 
are described on the fourth layer in Fig. 12. The normal mode, 
called a MOVIE mode, is a playback mode for a DVD-like 
environment. Of the two enhanced modes, the first, called 
5 a Java mode, is a playback mode used mainly with Java virtual 
machines. The second enhanced mode, called a Browser mode, 
is a playback mode used mainly with browsers. Since there 
are three modes on the fourth layer (i.e. the MOVIE mode, 
Java mode and Browser mode) , it is preferable to describe 

10 the modes with which dynamic scenarios can be executed. When 
wanting to describe control commands using commands that 
closely resemble DVD-oriented commands, MOVIE mode playback 
control procedures are preferably described. In this way, 
it is possible to have a playback device execute playback 

15 controls that closely resemble those in existing DVD playback 
devices. When control procedures are described using a page 
description language, Browser mode playback control 
procedures are preferably described. As such, it is possible 
to describe control procedures for accessing network sites, 

20 downloading files, and the like. ZZZ. CLASS in Fig. 4 is a Java 
mode dynamic scenario, ZZZ. HTM is a Browser mode dynamic 
scenario, and ZZZ. MOVIE is MOVIE-mode dynamic scenario. 



Dynamic Scenarios in MOVIE Mode 
25 The following description relates to dynamic scenarios 

20 
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in MOVIE mode. MOVIE objects (ZZZ. MOVIE) are dynamic 
scenarios described in commands similar to those used in DVD 
playback devices. MOVIE objects consist of playback commands 
instructing PL playback, commands to be executed prior to 
5 PL playback (pre-commands ) , and commands to be executed after 
PL playback (post-commands) . Pairings of one or more dynamic 
scenarios with PLs whose playback is instructed in the 
dynamic scenarios are known as Titles. Titles are units 
corresponding to entire movie works on BD-ROM. It should be 
10 noted that "MOVIE object'' is sometimes shortened to "M-OBJ" 
below . 



Technique for Describing Scenarios 

The above dynamic scenarios can be described using 
15 functions supplied from the third layer (static scenarios) . 
The following description relates to functions supplied from 
the third layer (static scenarios) . 



(a) Playback Functions: start playback of PlayLists 
20 specified by first arguments from positions specified by 
second arguments. 

Format: PlayPL (first argument, second argument) 
First arguments are able to specify PLs for playback 
using the numbers of PlayLists. Second arguments are able 
25 to specify playback start positions using Playltems included 

21 
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in the PLs, and arbitrary times, Chapters and Marks in the 
PLs. 

A PlayPL function specifying a playback start position 
using a Playltem is called a "PlayPLatPlayltem ( ) " , a PlayPL 
5 function specifying a playback start position using a Chapter 
is called a "PlayPLatChapter ( ) " , and a PlayPL function 
specifying a playback start position using time information 
is called a "PlayPLatSpecif ied Time ( ) " 

10 (b) Functions for status-acquisition and status setting of 
a playback device. 

The status of a playback device is shown in 32 
individual Player Status Registers (the setting values of 
these registers are called System Parameters (SPRM) ) , and 

15 32 individual General Purpose Registers (the setting values 
of these registers are called General Parameters (GPRM) ) . 

MOVIE objects, Java objects, and WebPage objects are 
able, for example, to set values in and acquire values from 
these registers by using the following functions (i) to (iv) • 

20 

(i) "Get value of Player Status Register" Function 

Format: Get value of Player Status Register (argument) 
This function acquires setting values of Player Status 
Registers specified by arguments . 

25 
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(ii) "Set value of Player Status Register"' Function 

Format: Set value of Player Status Register (first 
argument, second argument) 

This function causes values specified by second 
5 arguments to be set in Player Status Registers specified by 
first arguments. 

(iii) "Get value of General Purpose Register" Function 
Format: Get value of General Purpose Register 

10 (argument) 

This function acquires setting values of General 
Purpose Registers specified by arguments. 



(iv) "Set value of General Purpose Register" Function 
15 Format: Set value of General Purpose Register (first 

argument, second argument) 

This function causes values specified by second 

arguments to be set in General Purpose Registers specified 

by first arguments . 
20 The setting values (SPRM) of the Player Status 

Registers have the following meanings. The notation 

"SPRM(x) " below refers to the setting value of the x th Player 

Status Register. 



25 SPRM(O) : Reserved 
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SPRM(l) 

SPRM (2) 

5 SPRM(3) 
SPRM(4) 

SPRM(5) 

10 SPRM (6) 

SPRM(7) 

SPRM (8) 

15 

SPRM (9) 
SPRM(IO) 

SPRM(ll) - (12) 
20 SPRM(13) 
SPRM(14) 

SPRM(15) 

25 SPRM (16) 



PCT/JP2004/002026 

stream number of audio stream targeted for 
decoding 

stream number of graphics stream targeted 
for decoding 

number showing angle setting by user 
number of Title currently targeted for 
playback 

number of Chapter currently targeted for 
playback 

number of PL currently targeted for 
playback 

number of Playltem currently targeted for 
playback 

time information showing current playback 
time 

count value of navigation timer 

number of button currently in selected 

state 

Reserved 

setting of parental level by user 
setting related to video playback of 
playback device 

setting related to audio playback of 
playback device 

language code showing audio setting in 
24 
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playback device 
SPRM(17) : language code showing subtitle setting in 

playback device 
SPRM ( 18 ) : language setting for rendering menu 

5 SPRM (19) - (31) : Reserved 



Of these SPRMs, SPRM (4) is updated when a Title is 
selected by a user via a menu operation- SPRMs (5) -(7) are 
updated whenever the current playback time moves forward. 
10 That is, SPRM (7) is updated if the current playback time moves 
from one Playltem to another Playltem, SPRM (6) is updated 
if one PL is switched for another PL, and SPRM (5) is updated 
if one Chapter is switched for another Chapter. 

In this way, the Title and PL being played as well as 
15 the Playltem and Chapter being played in the PL are revealed 
by referring to SPRMs (4 ) - (7 ) . 

SPRM (8) , which is time information showing the current 
playback time (i.e. a point in time), is updated whenever 
picture data belonging to an AVClip is displayed. That is, 
20 if a playback device displays new picture data, SPRM (8) is 
updated to a value showing the display start time of the new 
picture data (Presentation Time) . 

Java objects and WebPage objects are able to find out 
the status of a playback device in detail by referring to 
25 the Player Status Registers using the "Get value of Player 
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Status Register" function and the "Get value of General 
Purpose Status Register" function. 

(c) There also exist branches from one dynamic scenario to 
5 another dynamic scenario, although these are not programming 
functions supplied from the third level (static scenarios) . 
Functions for executing branches from one dynamic scenario 
to another dynamic scenario include the following JMP and 
CALL functions. 

10 

JMP function 

Format: JMP Argument 
CALL function 

Format : CALL Argument 

15 

The JMP function is a branch for discarding the current 
dynamic scenario during operation, and executing 
branch-target dynamic scenario specified by an argument. JMP 
commands include direct reference commands that specify 

20 branch-target dynamic scenarios directly, and indirect 
reference commands that specify branch-target dynamic 
scenarios indirectly . 

The Call function is a branch for causing a 
branch-target dynamic scenario specified by an argument to 

25 operate after suspending the operation of the current dynamic 

26 
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scenario, and then resuming the operation of the suspended 
scenario once the branch-target dynamic scenario has ended. 
Resume commands are placed at the end of dynamic scenarios 
forming the branch-targets of Call commands. Resume commands, 
5 which are the so-called Return commands of subroutines, are 
for reactivating dynamic scenarios that are in a suspended 
state due to the execution of a Call function. Call commands, 
as with JMP commands, include direct reference commands that 
specify branch-target dynamic scenarios directly, and 

10 indirect reference commands that specify branch-target 
dynamic scenarios indirectly. 

Thus concludes the description of functions and 
variables supplied by the third layer (static scenario) . 

Fig. 13 shows the internal structure of a MOVIE object. 

15 A MOVIE object as shown in Fig. 13 comprises attribute 
information and a command string. The attribute information 
comprises a resume_intension_f lag, a menu_call_mask, and a 
Title_search_mask. 

The "resume_intension_flag // shows what controls the 

20 MOVIE object should perform when a menu call is requested. 
If the resume_intension_f lag is OFF, a status-setting 
routine is called when a user requests a menu call. At this 
time, the MOVIE object currently being executed is discarded, 
since the resuming operation described above is not performed. 

25 If the current MOVIE object is discarded in the playback 
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device, playback by the playback device needs to be restarted. 
There are two approaches regarding which playback position 
to return when restarting playback. One approach involves 
restarting playback from a state in the current MOVIE object 
5 immediately prior to the branching. 

The other approach involves restarting playback from 
the head of the plurality of commands structuring the current 
MOVIE object when the playback device has already executed 
some of the commands. Since the former approach involves 

10 complicated processing to recreate the pre-branching state, 
the present invention employs the latter approach. 

The latter approach to restarting playback is performed 
by initializing parameters showing the execution position 
of the current MOVIE object and parameters showing the 

15 current playback position. That is, SPRMs (5) - (8) showing the 
playback position are initialized when branching to a 
status-setting routine as the result of a menu call. If 
SPRMs (4) -(8) are saved after the initialization, 
SPRMs (4) -(8) can be reset in the original register during 

20 the restore processing performed after the status-setting 
routine ends. Since SPRMs (5) -(8) have been initialized, the 
playback device restarts playback using the reset values. 

On the other hand, if the resume_intension__f lag is ON, 
a MOVIE object for menu-call usage is jumped to after 

25 suspending the current MOVIE object and saving the SPRMs. 
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When processing of the MOVIE object for menu-call usage has 
ended, playback using the current MOVIE object is resumed 
after restoring the SPRMs. With MOVIE objects that realize 
language credits as shown in Figs.lA-lC, the 
5 resume__intension__f lag preferably is set to OFF. This is 
because if a menu call is requested and the language setting 
is changed from English to Japanese when the playback device 
is on PL#2, the playback device loses the playback resumption 
position . 

10 The creator is able to prevent operational errors 

occurring in the playback device when playback is performed 
by setting to OFF the resume_intension_f lag piece of 
attribute information in MOVIE objects where there is a 
danger of losing the playback position as described above. 

15 In this way, the creator can feel assured in creating MOVIE 
objects that perform playback controls according to SPRM 
settings . 

Since playback resumptions or restarts using the 
resume_intension_f lag are possible in MOVIE object units, 

20 creating MOVIE objects comprising one or two commands and 
branching these MOVIE objects allows playback resumptions 
or restarts to be performed in units of one or two commands. 
That is, MOVIE objects preferably are created depending on 
the units in which playback resumption or restarting is 

25 executed. Thus concludes the description of the 
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resume_intension_f lag . 

The "menu_call_mask" is a flag showing whether or not 
to mask menu calls. Requests for menu calls by a user are 
permitted if this flag is OFF and prohibited if ON. 
5 The "Title_search__mask" is a flag showing whether or 

not to mask Title searches. Requests for Title searches by 
a user are permitted if this flag is OFF and prohibited if 
ON. If the current MOVIE object is for playing a trailer 
(preview video) or warning video by the FBI, for instance, 
10 it is possible to make sure that the user views and understands 
the content of this video by setting the Title_search__mask 
in the MOVIE object to ON. 

Specific exemplary setting of the 

resume_intension_f lag and Title_search_mask are described 
15 below. Figs . 14A-14C show the exemplary description of a MOVIE 
object when realizing a language credit and playback controls 
resulting from this exemplary description. 

In the exemplary MOVIE object description shown in 
Fig.l4A, resume_intension_f lag, menu_call_mask, and 
20 Title_search_mask have been added to the exemplary MOVIE 
object description shown in Fig.lA. The 

resume_intension_f lag, menu__call_mask, and 

Title_search_mask have all been set to "0". Fig.l4B shows 
a playback control based on the MOVIE object described in 
25 Fig.l4A. The exemplary description in Fig.l4A realizes 
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conditional playback such that PL#4 is played (Link ( PL#4 , 
PI#1)) if the language setting (SPRM(O)) in the playback 
device is "Japanese", and PL#2 is played (Link(PL#2, PI#1) ) 
if the language setting in the playback device is anything 
5 other than "Japanese" (i.e. "else"). Here, the playback 
device proceeds on PL#2 if the language setting in the 
playback device is English. 

Assume that the user requests a menu call when the 
playback device is on PL#2 (rgl) . In this case, the processing 
10 in Figs . 15A-15C to restart playback is performed because of 
the resume_intension_f lag in the given MOVIE object being 
set to "0". Figs . 15A-15C show processing in the playback 
device for restarting playback. If the resume_intension_f lag 
is set to "0", SPRMs (4) ~ (8) showing the playback position 
15 are saved to memory (Fig.l5B) after initializing 
SPRMs(5)-(8) (Fig.lSA). A branch brl to a status-setting 
routine rcl is executed after SPRMs (4) -(8) have been saved. 
Assume that the user changes the language setting from 
English to Japanese using this status-setting routine 
20 (English — > Japanese in Fig.lSB). Once processing of the 
status-setting routine has ended, the playback device 
restores SPRMs ( 4 ) - ( 8 ) saved in memory to the register . Since 
the initialized SPRMs (5) -(8) showing the playback position 
are set in the register, the playback position is set to the 
25 head of the Title in Fig.l4B. As a result, restarting from 
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the head of the Title is carried out. Moreover, in the Fig.l4C 
example, the playback position is set to the Title head 
because of the playback device not initializing SPRM(4), 
which shows the number of the Title currently being played. 
5 If this Title number is initialized, playback is restarted 
from a Title menu that encourages the user to select a Title. 

A further exemplary description is shown Figs . 16A-16C . 
Figs . 16A-16C show the exemplary description of a MOVIE 
ob j ect when realizing branching that results from a question, 

10 and playback controls resulting from this exemplary 
description. The exemplary MOVIE object description shown 
in Fig. 16A differs from that shown in Fig. 14A in that Fig. 16A 
realizes dialogue playback controls, whereas Fig. 14 realizes 
a language credit. In Fig.l6A, PL#1 is a question scene, and 

15 PL#2 and PL#4 are scenes that appear when answers (1) and 
(2) are respectively selected in response to the question. 
Which answer to select is set in GPRM(O) . Playback switching 
resulting from IF statements, is performed according to 
GPRM ( 0 ) . GPRM ( 0 ) , which is merely a general-purpose register 

20 value, is not updated in response to the setting of 
status-setting routines . Also, in this exemplary description, 
resume__intension_f lag is set to "1". 

Fig.l6B shows a playback control based on the MOVIE 
object described above. 

25 Assume that the user requests a menu call when the 
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playback device is on PL#2 . In this case, the playback device 
omits Fig.l5A and performs the Fig.lSB processing because 
of the resume_intension_f lag in the given MOVIE object being 
set to "1". That is, SPRMs(4)-(8) showing the playback 
5 position are saved from the register to memory. Branch brl 
to status-setting routine rcl is executed after SPRMs (4 ) - (8 ) 
have been saved. Assume that the user changes the language 
setting from English to Japanese using this status-setting 
routine (English— ► Japanese in Fig.l6B). Once processing of 

10 the status-setting routine has ended, the playback device 
executes processing to restore SPRMs (4) -(8) from memory to 
the register. Since SPRMs (4) -(8) are set in the register as 
a result of the restoration, the playback position is such 
that playback is resumed from the previous playback position . 

15 A further exemplary MOVIE object is shown in 

Figs . 17A-17C . If SPRM(13), which is the parental level 
setting in the playback device, is "kids" in the MOVIE object 
shown in Fig.l7A (if ( SPRM ( 13 ) =="kids" ) ) , PL#4 
(Link (PL#4, PL#1) ) is played, and if the parental level in 

20 the playback device is any other setting apart from "kids" 
(i.e. "else"), PL#2 (Link ( PL#2 , PL#1 ) ) is played. Here, it 
is possible to realize a so-called parental lock, since 
playback switches between extreme scenes and child-oriented 
scenes depending on the SPRM (13) setting when PL#2 and PL#4 

25 are assumed to be an extreme scene and a child-oriented scene, 
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respectively. Since SPRM (13) can be changed using a 
status-setting routine, the resume_intension_f lag in the 
attribute information is set to "0" . 

Fig.l7B shows a playback control by the MOVIE object 
5 described above. This playback control is for setting 
SPRM (13) in the playback device to "kids" . PL#4 is thus played 
since even SPRM (13) in the playback device is set to show 
"kids" (Link(PL#4,PL#l) ) . 

Assume that a menu call is requested when the playback 
10 device is on PL#4. Since the resume_intension_f lag is set 
to "0" in Fig.l7A, SPRMs(4)-(8) are saved (Fig.l5B) after 
initializing SPRMs(5)-(8) (Fig.lSA). Branching to the 
status-setting routine is then executed. 

Assume here that in this status-setting routine an 
15 operation is performed to update SPRM (13) and the 
status-setting routine has ended. Since SPRMs ( 4 ) - ( 8 ) are 
returned to the register in the playback device in the 
restoration performed after the end of the status-setting 
routine (Fig.l5B), the playback position is set to the head 
20 of the Title and playback is restarted from this position 
(Fig.l7C) . 

The examples shown above in Figs. 14, 16 and 17 are 
examples involving the resume_intension_flag setting. 
Figs . 18A-18B show an example of Title_search_mask being set 
25 in MOVIE objects. 
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MOVIE object (0) in Fig. 18A is the MOVIE object executed 
prior to MOVIE object (1) shown in Fig.l4A. In this MOVIE 
object, PL#6 is a preview (1) , PL#7 is a preview (2) , and PL#5 
is video for having the user select one of PL#6 and PL#7 . 
5 Which of the preview is selected is set in GPRM(O) . Playback 
switching by an IF statement is performed according to 
GPRM(O). Jmp Movie Object (1) is a branch command executed 
after the switching, MOVIE obj ect ( 1 ) being the branch target . 
Since Title_search_mask in MOVIE object (1) is set to "1", 

10 Title search requests are masked while playback controls are 
being performed by the MOVIE object. Conversely, a Title 
search will be activated if either of previews (1) and (2 ) 
is viewed (Fig.l8B) . Since a control is realized to "prohibit 
title searches until either of previews (1) and (2) is viewed" 

15 by merely setting a 1-bit Title_search_mask, freedom in 
describing the control is increased. Let us draw a comparison 
with when the same playback controls as in Fig.l8B are 
performed using Japanese patent application no. 2856363. 
According to Japanese patent application no. 2856363, the 

20 permissibility of user operations is set with respect to 
individual playback path, which means that when there is a 
large number of previews that can be played alternately, the 
number of playback paths set to prohibit user operations must 
equal that number. As such, the number of playback paths that 

25 must be provided increases with the number of playable 
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previews, thus inviting complications. 

In contrast, with the MOVIE object in Figs . 18A-18B, a 
playback control for refusing Title searches until a preview 
is played can be described simply by setting the 
5 Title_search_mask in the MOVIE object to "1", even when there 
is a large number of alternately playable previews . 

Because of the easy description of this playback 
control, MOVIE objects pertaining to the present embodiment 
are effective when distributing Titles. 

10 Thus concludes the description relating to an 

embodiment of a recording medium pertaining to the present 
invention. The following description relates to an 
embodiment of a playback device pertaining to the present 
invention. Fig. 19 shows the internal structure of a playback 

15 device pertaining to the present invention. A playback device 
pertaining to the present invention comprises two main parts, 
namely, a system LSI and a drive device, and can be produced 
industrially by mounting these parts to the cabinet and 
substrate of a device . The system LSI is an integrated circuit 

20 that integrates a variety of processing units for carrying 
out the functions of the playback device. A playback device 
thus produced is structured from a DVD drive 1, a track buffer 
2, a PID filter 4, a video decoder 5, a picture plane 6, an 
audio decoder 7, a graphics plane 8, a graphics decoder 9, 

25 an adder 10, a static scenario memory 11, an playback control 
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engine 12, a player register 13, a BACKUP memory 14, a dynamic 
scenario memory 15, a DVD-like module 16, a Java module 17, 
a BROWSER module 18, a UO controller 19, a module manager 
20, and a dispatcher 21. 
5 BD-ROM drive 1 performs loading/ejecting of BD-ROMs, 

and accesses loaded BD-ROMs. 

Track buffer 2 is a FIFO memory that stores ACCESS UNITs 
read from BD-ROMs on a first-in first-out basis. 

PID filter 4 retrieves ACCESS UNITs from track buffer 
10 2 and converts TS packets structuring ACCESS UNITs into PES 
packets. Desired PES packets obtained as a result of the 
conversion are outputted to one of video decoder 5, audio 
decoder 7, and graphics decoder 9. The outputting is 
performed while referring to the IDs (PIDs) of the PES packets. 
15 PES packets whose PID shows video are outputted to video 
decoder 5, PES packets whose PID shows audio are outputted 
to audio decoder 7, and PES packets whose PID shows graphics 
image are outputted to graphics decoder 9. 

Video decoder 5 writes uncompressed-format pictures 
20 obtained by decoding the plurality of PES packets outputted 
from PID filter 4 to picture plane 6. 

Picture plane 6 is a memory for storing 
uncompressed-format pictures . 

Audio decoder 7 outputs uncompressed-format audio data 
25 obtained by decoding PES packets outputted from PID filter 
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4. 

Graphics plane 8 is a memory having a single screen 
capacity area that can stores one screen worth of graphics 
images . 

5 Graphics decoder 9 writes raster images obtained by 

decoding graphics streams to graphics plane 8. Subtitles, 
menus and the like appear on a screen as a result of decoding 
graphics streams. 

Adder 10 outputs the result of synthesizing images 

10 expanded in graphics plane 8 with uncompressed- format 
picture data stored in picture plane 6. 

Static scenario memory 11 is a memory for storing 
current PL information, Clip information, and the like. 
Current PL information is the piece currently targeted for 

15 processing from among the plurality of PL information 
recorded on the BD-ROM. Current Clip information is the piece 
currently targeted for processing from among the plurality 
of Clip information recorded on the BD-ROM. 

Playback control engine 12 executes various functions, 

20 such as AV playback functions (1), PlayList playback 
functions (2), and status-acquisition/setting functions (3) 
in the playback device. AV playback functions in the playback 
device, which consist of a function group similar to that 
found in DVD and CD players, refer to the execution in response 

25 to user operations of processing such as Play, Stop, Pause-On, 
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Pause-Off, Still-Off, Forward Play (fast), Reverse Play 
(fast), Audio Change, Subtitle Change, and Angle Change. PL 
playback functions refer to the execution of Play, Stop and 
other of the AV playback functions in accordance with PL 
5 information. Playback control engine 12 carries out the 
functions of the third layer (playback controls based on 
static scenarios) in the layer model by executing these PL 
playback functions. On the other hand, playback control 
engine 12 executes functions (2) to (3) in accordance with 

10 function calls from DVD-like module 16, Java module 17, and 
BROWSER module 18. That is, playback control engine 12 
executes the functions of playback control engine 12 in 
response to instructions resulting from user operations and 
instructions from superordinate layers in the layer model. 

15 Player register 13 comprises 32 individual System 

Parameter Registers and 32 individual General Purpose 
Registers. The stored values of these registers are used in 
programming as SPRMs and GPRMs . Since System Parameter 
Registers and General Purpose Registers are managed by 

20 playback control engine 12, which is separate from modules 
16 to 18, it is possible, even when a change in playback modes 
occurs, for instance, for the module that executes the 
playback mode after the switch to find out the playback status 
of the playback device simply by referring to SPRMs ( 0 )-( 31 ) 

25 and GPRMs ( 0 )-( 31 ) in playback control engine 12. 

39 



WO 2004/074976 



PCT/JP2004/002026 



BACKUP memory 14 is a stack memory for saving stored 
values of the playback device register when one of modules 
16 to 18 executes Suspend. The stored values of BACKUP memory 
14 are restored to the stored values of the register possessed 
5 by the playback device when one of modules 16 to 18 executes 
Resume in a dynamic scenario. The stored values of registers 
are stored in a first-in first-out basis in the event that 
one of modules 16 to 18 performs Suspend two or more times. 
If the number of stored values is greater than or equal to 

10 the number of slots in the stacks, stored values that have 
been saved are overwritten. SPRMs saved to BACKUP memory 14 
includes the number of the Title currently being played 
(Title Number) , the currently-being-played Chapter number, 
the currently-being-played PL number (PlayList Number) , the 

15 currently-being-played Playltem number (Playltem Number), 
the number of the button in a selected-state (Selected 
Button) , and time information showing the current playback 
time . 

Dynamic scenario memory 15 is a memory storing the 
20 current dynamic scenario, and is jointly processed by 

DVD-like module 16, Java module 17 and BROWSER module 18. 

The current dynamic scenario is the dynamic scenario 

currently targeted for processing from among the plurality 

of scenarios recorded on the BD-ROM. 
25 DVD-like module 16, which is a DVD virtual player that 
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is the main execution body of MOVIE mode, executes current 
MOVIE objects read to dynamic scenario memory 15. 

Java module 17 is a Java platform formed from a Java 
virtual machine, a configuration and a profile. 
5 Java module 17 creates current Java objects from 

ZZZ. CLASS files read to dynamic scenario memory 15, and 
executes the current Java objects. The Java virtual machine 
converts Java objects described using a Java language into 
native codes for the CPU in the playback device, and has the 
10 CPU execute the native codes. 

BROWSER module 18, which is a browser that is the main 
execution body of Browser mode, executes current WebPage 
objects read to dynamic scenario memory 15. 

UO controller 19 detects user operations performed with 
15 respect to a remote controller, a front panel of the playback 
device or the like, and outputs information showing detected 
user operations (hereinafter "UO information'') to module 
manager 20. 

Module manager 20 holds an Index Table read from the 
20 BD-ROM and performs mode management and branch controls . Mode 
management performed by module manager 2 0 refers to the 
allocation of modules; namely, which of modules 16 to 20 is 
to execute what dynamic scenarios. The principle of module 
allocation is that DVD-like module 16 executes dynamic 
25 scenarios. This principle is upheld even if in the case of 
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branches resulting from intra-modes (i.e. branches within 
the same mode) . An exception is when inter-mode branching 
occurs (i.e. branching between modes) . When branching from 
a MOVIE object to a java ob j ect/Webpage object occurs, Java 
5 module 17 and BROWSER module 18 respectively execute the 
current object. 

Dispatcher 21 chooses only UOs apposite to the current 
mode of the playback device, and passes chosen UOs on to the 
module for executing the current mode. For example, if arrow 

10 key or activate UOs are received during the execution of MOVIE 
mode, dispatcher 21 outputs these UOs to the module executing 
MOVIE mode. These UOs are only required for menu behavior 
in MOVIE mode, and are not required by Java and Browser modes . 

Thus concludes the description of the playback device 

15 elements. Module manager 20 will now be described in detail. 

Module manager 20 can be implemented by having a general 
purpose CPU read programs for performing the processing 
procedures shown in Figs. 20 to 22. Figs. 20 to 22 are 
flowcharts showing the processing procedures performed by 

20 module manager 20. Branch controls performed by module 
manager 2 0 will now be described while referring to these 
flowcharts. In the Fig. 20 flowchart, module manager 20 
retrieves a filename from the First Play Index in the Index 
Table (step SI) . The Index Table is integrated information 

25 relating to MOVIE objects, and the First Play Index is an 
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Index showing MOVIE objects that describe BD-ROM startup 
procedures . 

Once the filename has been retrieved, module manager 
20 sets the current mode to MOVIE mode (step S2), sets the 
5 dynamic scenario of the retrieved filename as the current 
dynamic scenario (step S3), reads the current dynamic 
scenario i to memory (step S4) , and executes current dynamic 
scenario in memory (steps S5-S9) . 

Steps S4 to S9 are executed whenever the current dynamic 
10 scenario is newly set. 

Steps S5 to S9 form a loop processing procedure in which 
the processing of steps S6 to S9 is repeated for each command 
structuring a scenario. The "x" in the flowcharts is a 
variable that identifies processing targets from among the 
15 commands structuring a dynamic scenario. The loop processing 
involves module manager 2 0 repeating the following 
processing: initializing variable x (step S5), having the 
module of the current mode execute command x included in the 
current dynamic scenario i (step S6) , performing the judgment 
20 processing defined in steps S7 to S8, and then incrementing 
variable x (step S9) , before returning the step S6. The 
processing of steps S6 to S9 is repeated for all of the 
commands structuring the scenario. 

If a UO occurs during execution of the loop processing 
25 (step S7=YES) , module manager 2 0 outputs the UO to the module 



WO 2004/074976 



PCT/JP2004/002026 



executing the current mode (step S2 6) after passing though 
the judgment processing of steps S10 to S12 . 

Step S10 is a step for judging whether the user 
operation is a menu call. If a menu call, module manager 20 
5 performs the save processing of one of steps S15 and S16 in 
Fig. 21 after passing through the judgments of steps S13 and 
S14. Module manager 20 then sets a dynamic scenario for 
performing status setting as the current dynamic scenario 
i (step S17) , and returns to step S4. Since a dynamic scenario 

10 for performing status setting becomes the current dynamic 
scenario i as a result of step S17, the dynamic scenario for 
status setting is executed at steps S5 to S9. 

Step S13 is a judgment as to whether the menu__call__mask 
in the current dynamic scenario i is "1". If "1", module 

15 manager 20 returns to step S8 in Fig. 20 without performing 
any processing. 

Step S15 is processing to suspend the current dynamic 
scenario i and save variable x and SPRMs(4) to (8) in BACKUP 
memory 14. Step S15 is executed if the resume__intension_f lag 

20 is "1" (step S14=YES) . 

Step S16 is processing to suspend the current dynamic 
scenario i and save variable x and SPRMs(4) to (8) in BACKUP 
memory 14 after initializing variable x and SPRMs (5) to (8) . 
Step S16 is executed if the resume_intension_f lag is "0" 

25 (step S14=NO) . 
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Step Sll is a judgment as to whether the user operation 
requests a Title search. If a Title search is requested, 
module manager 2 0 judges in step S18 whether the 
Title_search_mask of the current dynamic scenario i is "1". 
5 If "1", module manager 20 sets a dynamic scenario for 
performing title searches as the current dynamic scenario 
i in step S19. 

Step S12 is for executing dispatch processing of the 
UO. Dispatch processing of a UO involves module manager 2 0 

10 judging whether a UO that occurs during command execution 
is an arrow key or activate operation (step S12) , and if the 
current mode is MOVIE mode (step S2 0) , outputting the UO to 
the module that executes the current mode. If the UO that 
occurred during command execution is other than an arrow key 

15 or activate operation, the UO is simply outputted to the 
module that executes the current mode (step S2 6) . If the UO 
that occurred during command execution is an arrow key or 
activate operation but the current mode is not MOVIE mode, 
the UO is not outputted to a module. Thus concludes the 

20 description of dispatch processing. 

The requirement for ending the loop processing of steps 
S4 to S19 is that judgment in step S8 be YES. If the command 
x is the final command in dynamic scenario i (step S8=YES) , 
a judgment is conducted as to whether a Resume command is 

25 last in dynamic scenario i (step S21 in Fig. 22). 
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A Resume command is a command instructing the playback 
device to perform status-restoration of the dynamic scenario 
that is the call source. Resume commands are placed at the 
end of dynamic scenarios for status setting (i.e. 
5 status-setting routines) . 

If a Resume command exists at the end of dynamic 
scenario i, module manager 20 sets the suspended dynamic 
scenario as dynamic scenario i (step S22), sets the mode of 
dynamic scenario i as the current mode (step S23) , restores 

10 the SPRMs saved in BACKUP memory 14 to the register (step 
S24) , and returns variable x to the saved value (step S25) . 

Here, since SPRMs (4) -(8) and variable x are saved to 
memory 14 after being set to values showing the playback 
position up until that point in time if the 

15 resume__intension_f lag is "1", the player register shows the 
playback position prior to the call for a status-setting 
routine as a result of the restore processing performed at 
step S24. Processing to resume Title playback is performed 
because of these values being set in the player register. 

20 On the other hand, since SPRMs ( 4 ) - ( 8 ) and variable x 

are saved to memory 14 after SPRMs (5) - (8) and variable x have 
been initialized if the resume_intension_f lag is "0", the 
player register shows the playback start position of the 
Title currently being played. Processing to restart the Title 

25 is performed because of these values being set in the player 
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register. It should be noted that although in the flowcharts 
of Figs. 20 to 22 the restart is executed from the Title 
currently being played, the restart may be performed with 
respect to the entire BD-ROM by initializing all SPRMs 
5 showing playback positions at step S16. Thus concludes the 
description of processing procedures performed by module 
manager 2 0 . 

According to the present embodiment as described above, 
control procedures pertaining to menu calls at an upper-most 

10 layer (dynamic scenarios) are set in a layer mode comprising, 
from bottom to top, streams, playback paths, and dynamic 
scenarios. In particular, when Titles that the user wants 
to create are for realizing language credits, it is possible 
to realize controls in which menu calls are accepted but 

15 playback is not resumed. As a result, it is possible to easily 
create two types of Titles, namely, those that permit menu 
calls and those that prohibit menu calls, even with the same 
streams and playback paths. Since there is no increase in 
the number of playback paths and streams with the creation 

20 of Titles, it is possible with little effort to increase the 
number of variations having different control procedures. 

Embodiment 2 

Embodiment 2 relates an enhancement that allows Stop 
25 and Restart in a playback device to be avoided. Stop and 

47 
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Restart in a playback device can occur when any of the 
following three situations arise in the playback device, 

1) When branching to a Java object or a WebPage object 
occurs with a BD-ROM corresponding to Java mode and Browser 

5 mode loaded in a playback device corresponding only to MOVIE 
mode . 

2) When attempting to read a non-existent stream, or 
attempting to branch to a Title structured from a 
non-existent dynamic scenario. 

10 3) When recovering an error that occurs with a Java 

object is not possible. 

With the present embodiment for avoiding Stop and 
Restart, an INDEX relating to Titles for use in exception 
processing is provided in information for 

15 integrating/managing dynamic scenarios. 

INFO.BD shown in Fig. 4 is information for 
integrating/managing dynamic scenarios in MOVIE mode, Java 
mode, and Browser mode. 

Fig.23A shows an internal structure of INFO.BD. As 

20 shown in Fig.23A, INFO.BD includes an Index Table. The Index 
Table is an indirect reference table that is referenced when 
branching from one dynamic scenario to another dynamic 
scenario, and comprises Indexes corresponding one-to-one 
with a plurality of labels. In each Index is described a 

25 filename of a dynamic scenario corresponding the label of 

48 
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the Index. As shown in Fig. 23B, Each filename comprises a 
file body and an extension. The labels include Title#l~#m, 
Title#m+l~#n, and Title#0. The Index Table is also referred 
to from dynamic scenarios of any of the three modes . Branching 
5 from MOVIE objects to Java objects or from MOVIE objects to 
WebPage objects is only possible when via the Index Table. 
To rephrase, it is not possible to branch from a MOVIE object 
to a Java or WebPage object that does not have an Index in 
the Index Table. 
10 The TITLE#l~#m Indexes relate to the 1 st to m th Titles 

entered in the BD-ROM. In these Indexes are described the 
filenames of MOVIE objects that are to be branch targets when 
the 1 st to m th Title number^ are selected. Fig.23B shows the 
content of TITLE#l~#m. As shown in Fig.23B, the filenames 
15 of MOVIE objects are described in the Title#l~#m Indexes. 
Each filename comprises a file body (ZZZ) and an extension 
( .MOVIE) . 

The TITLE#m+l-#n Indexes relate to the 1 st to m+l th 
Titles entered in the BD-ROM. In these Indexes are described 

20 the filenames of WebPage objects/ Java objects that are to 
be the branch target when the m+l th to n th Title numbers are 
selected. Fig.23C shows an internal structure of the 
TITLE#m+l~#n Indexes. As shown in Fig.23C, in each of Indexes 
TITLE#m+l~#n is stored either the file body (ZZZ) and 

25 extension (.CLASS) of a Java object or the file body (ZZZ) 
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and extension (.HTM) of a WebPage object. It should be noted 
that Index format may be as shown in Fig. 23D . The Index in 
the Fig.23D format has an attribute area showing an attribute 
of the branch-target Title, the Index being structured to 
5 show in the attribute area whether the dynamic scenario of 
the corresponding branch-target Title is MOVIE mode ("00" 
setting) , Java mode ("01" setting) , or Browser mode ("10" 
setting) . 

TITLE#0INDEX relates to an exception processing Title, 

10 and stores the filename of a MOVIE mode scenario. The 
exception processing described here is executed when any of 
the above three situations arises. A playback device in which 
enhanced mode execution is not possible for any of these three 
reasons is called a core system. On the other hand, a playback 

15 device in which program execution using a Java virtual 
machine or a Browser is possible is called a full system. 
Indirect referencing of a BD-ROM by a core system and a full 
system is described below while referring to Figs . 24A-24B . 
The description of indirect referencing assumes a BD-ROM on 

20 which a plurality of dynamic scenarios is recorded (001 .MOVIE, 
002. MOVIE, 003. MOVIE, 001. CLASS, 002. CLASS, 003. CLASS, 

...) , as shown in Fig. 24A. Fig . 24B shows an exemplary 
description of an Index Table when the plurality of dynamic 
scenarios shown in Fig . 24A is recorded on the BD-ROM. In the 

25 exemplary description shown in Fig.24B, the filenames of 
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MOVIE mode scenarios (001. MOVIE, 002. MOVIE, 003. MOVIE, ...) 
are described in Title#llndex to Title#mlndex . On the other 
hand, the filenames of enhanced mode scenarios (001. CLASS, 
002. CLASS, 003. CLASS, ...) are described in Title#m+llndex to 

5 Title#nlndex . 

Fig.25A shows indirect referencing in a full system 
when the Index Table is described as in Fig. 24B. Because of 
the Index Table being described as such, filenames "001 .MOVIE, 
002. MOVIE, 003. MOVIE, ..." are retrieved from Title#llndex to 

10 Title#mlndex when executing branch commands specifying 
labels Title#l to Title#m as branch targets, and filenames 
"001. CLASS, 002. CLASS, 003. CLASS, ..." are retrieved from 
Title#m+llndex to Title#nlndex when executing branch 
commands specifying labels Title#m+1 to Title#n as branch 

15 targets. Dynamic scenarios specified by these filenames are 
then read to memory and executed. Thus concludes the 
description of indirect referencing by a full system. 

Fig . 25B shows indirect referencing in a core system. 
Filenames " 001. MOVIE, 002. MOVIE, 003. MOVIE, ..." are retrieved 

20 from Title#llndex to Title#mlndex when executing branch 
commands specifying labels Title#l to Title#m as branch 
targets. However, when executing branch commands specifying 
labels Title#m+1 to Title#n as branch targets, filename 
"000. MOVIE" is retrieved from Title#01ndex in place of 

25 Title#m+llndex to Title#nlndex . The playback device then 
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executes the dynamic scenarios specified by these filenames . 
Thus concludes the description of indirect referencing by 
both a full system and a core system. 

Fig. 2 6 schematically shows how branching from a MOVIE 
5 object to a Java object is performed. The MOVIE object in 
Fig. 2 6 comprises a pre-command in which GPRM(O) is set to 
"0", a command (PlayPL ( PL#1 ) ) instructing the playback 
device to perform PL playback, and a post-command instructing 
the playback device to perform branching to another dynamic 

10 scenario ( IF (GPRM ( 0 ) =0 ) { Jmp Title#m} else { Jmp Title#m+1 } ) . 
As a result of this pre -command, GPRM(0) is initialized prior 
to PL playback. Also, as a result of this post-command, 
branching is performed to MOVIE obj ect#m+l if GPRM(0) shows 
yy Q" when initialized. On the other hand, branching is 

15 performed to another Title (Title#m) if a button selection 
is performed when a menu is displayed and GPRM(0) is set to 
a value other than "0". 

Interactive graphics streams for realizing dialogue 
processing as described below are multiplexed onto AVClips. 

20 Interactive graphics streams are streams displaying buttons 
corresponding to characters A, B and C, GPRM(0) being set 
to "1" when character A is determined, "2" when character 
B is determined, and "3" when character C is determined. 

The arrows jnl and jn2 in Fig. 26 symbolically indicate 

25 the branching from a MOVIE object to a Java object. Jmp 
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Title#m+1 in Fig. 2 6 is a branch command in a Java object, 
and specifies the Java object as a branch target using an 
indirect referencing format via the Index of label Title#m+1 . 
The filename of the Java object is described in the Index 
5 of label Title#m+1, the playback device being able to find 
out which file to read as the Java object by referring to 
this Index. 

In the Java ob j ect , "A . drawCharacter ( ) ; " means that the 
Object of character A is drawn on the screen using one of 

10 the methods (i.e. the drawCharacter function in Fig. 26) of 
the Class "character A" . Likewise, "B . drawCharacter ( ) ; " and 
"C . drawCharacter (); " mean respectively that the Objects of 
characters B and C are drawn on the screen using one of the 
methods (i.e. the drawCharacter function in Fig. 26) of the 

15 Classes "character B" and "character C". 

Since "A. drawCharacter (); "B . drawCharacter (); " and 
"C . drawCharacter (); " are executed exclusively depending on 
the value of GPRM ( 0 ) (IF statements in Fig. 26), the CG of 
character A is drawn if GPRM(O) is "1", the CG of character 

20 B is drawn if GPRM(0) is "2", and the CG of character C is 
drawn if GPRM(0) is "3". 

Fig. 27 shows what kind of branching is performed when 
a BD-ROM having the scenarios shown in Fig. 2 6 recorded 
thereon is loaded in a core system playback device. Depicting 

25 the arrows in Fig. 26 using the broken line hsl in Fig. 27 shows 
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that the branching in Fig. 2 6 is no longer valid because of 
the core system lacking an element for executing Java objects. 
The arrow jsl in Fig. 27 shows branching used in exception 
processing performed in place of the invalid branching. The 
5 branching used in exception processing is indirect 
referencing via the Index of Title#0. The filename of MOVIE 
object sgl is stored in the Index of Title#0, MOVIE object 
sgl being read by the playback device and executed in this 
branching. Because of displaying video in MOVIE objects when 

10 the BD-ROM is loaded in a playback device having only a core 
system, it is possible to avoid Stop and Restart. 

Thus concludes the description relating to enhancement 
of the BD-ROM in embodiment 2. Enhancements on the playback 
device side will now be described. 

15 A characteristic of module manager 2 0 in embodiment 2 

is the branch control. Branch controls read dynamic scenarios 
identified as branch targets to memory, and have one of 
DVD-like module 16, Java module 17 and BROWSER module 18 
execute the dynamic scenarios. Identification is necessary 

20 particularly when branch-target dynamic scenarios are 
specified using an indirect referencing format. 
Identification is carried out by referring to the 
branch-target labels of branch commands and retrieving 
filenames from Indexes corresponding to the labels. A 

25 judgment as to whether mode switching is necessary is 
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performed in conjunction with this identification. The 
mode-switching judgment is performed by referring to the 
Index corresponding to the branch-target label so as to 
determine the file extension stored or the mode shown by 
5 stored attribute information. The stored content of the Index 
reveals whether mode switching is necessary. If mode 
switching is necessary, the branch-target dynamic scenario 
is read to memory, and a mode-transition request is outputted 
to the module that executes the post-switching mode. As a 

10 result of the mode-transition request being outputted, the 
module executing the post-switching mode executes the 
branch-target dynamic scenario in memory. 

The processing procedures by module manager 2 0 in 
embodiment 2 as a result of module manager 20 performing the 

15 above branch controls are as shown in Fig. 28. Fig. 28, being 
based on the flowchart shown in Fig. 20, depicts the 
differences between the two flowcharts. 

Although commands in the current dynamic scenario i are 
executed one at a time by repeating the steps S6 to S9, step 

20 S30 has been newly added to the loop processing of steps S6 
to S9 in the Fig. 28 flowchart. 

Step S30 is a judgment as to whether or not command x 
is a branch command. If Step S30 is YES, module manager 20 
returns to step S4 after setting the current dynamic scenario 

25 to the new dynamic scenario in steps S31 to s43. As a result, 
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the new dynamic scenario is read to memory and executed. 

The following description relates to the processing in 
steps S31 to S43. This processing involves branch controls, 
and differs depending on the judgment results of steps S31, 
5 S34, S39 and S42. Step S31 is a judgment as to whether the 
branch target of a branch command is described using a Title 
label. If YES, module manager 2 0 acquires the branch-target 
label Titlej after passing through the step S42 judgment 
(step S32), and retrieves filenamej from Indexi of Titlej 
10 in the Index Table (step S33) . If NO, module manager 2 0 
retrieves filenamej showing the branch target (step S41) . 

Step S3 4 is a judgment as to whether the branch command 
is a Call command or a Jmp command. If a Call command, module 
manager 2 0 saves variable x and SPRMs after suspending the 
15 current dynamic scenario i (step S35) . If a Jmp command, 
module manager 2 0 discards the current dynamic scenario i 
(step S36) . 

Having passed through the above processing, module 
manager 20 sets the dynamic scenario identified from 

20 filenamej as the current dynamic scenario i (step S37), and 
sets the playback mode identified from the retrieved 
extension as playback mode k (step S38) . After these settings, 
module manager 20 executes step S39. Step S39 is a judgment 
as to whether playback mode k is the current playback mode. 

25 If not the same, module manager 20 sets playback mode k as 
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the current playback mode (step S40) , and transfers to step 
S4. After that the processing of steps S4 to S9 is repeated 
with respect to the newly set current dynamic scenario. Step 
S42 is a judgment as to whether the playback device is a core 
5 system or a full system, and if a core system, module manager 
20 retrieves the filename from Index of Title#0, and sets 
this as the branch target (step S43) . 

Since the playback device is set as a core system when 
difficulties are encountered with enhanced mode execution 
10 for some reason, and branching performed while referring to 
an Index in the Index Table for use in exception processing, 
it is possible according to the present embodiment as 
described above to avoid Stop, Restart, and the like. 



15 Embodiment 3 

Embodiment 3 relates to enhancements when playback 
devices and BD-ROMs of various specifications are introduced. 
When there is strong pressure to quickly commercialize 
BD-ROMs and playback devices, BD-ROM versions with few 

20 supportable functions, such as version 1 . 0 that only supports 
MOVIE mode and version 1.1 that supports MOVIE mode and 
enhanced modes, end up being commercialized and thrown on 
the market. In this case, the market end up getting populated 
with a number of versions of playback devices, such as version 

25 1.0 and version 1.1 BD-ROMs, and version 1.0 and version 1.1 
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playback devices . This being the case, branching from a MOVIE 
object in MOVIE mode to a MOVIE object in an enhanced mode 
may occur with a version 1.1 BD-ROM loaded in a version 1.0 
playback device, for example . In this case, it is not possible 
5 to execute the MOVIE object in an enhanced mode since the 
version 1.0 playback device only has a module for MOVIE mode. 
Thus with the present embodiment, Index Tables relating to 
all available versions are recorded on BD-ROMs . Fig.29A is 
a version 1 . 1 BD-ROM. A version 1 . 1 Index Table and a version 

10 1.0 Index Table are recorded on the BD-ROM in Fig.29A. 
TITLE#1 INDEX to TITLE#mINDEX exist in the version 1.0 Index 
Table. As shown in embodiment 2, these INDEXs are referred 
to when branching to MOVIE-mode dynamic scenarios. 

TITLE# 1INDEX to TITLE#mINDEX, TITLE#m+l INDEX to 

15 TITLE#nINDEX, and TITLE# 0 INDEX exist in the version 1 . 1 Index 
Table. As shown in embodiment 2, these INDEXs are referred 
to when branching to MOVIE-mode dynamic scenarios, enhanced 
mode dynamic scenarios, and dynamic scenarios used in 
exception processing. 

20 When one of these versions of a BD-ROM is loaded in a 

playback device, the playback device selects MOVIE objects 
using the Index Table matching the version of the playback 
device from among the Index Tables relating to the plurality 
of versions recorded on the BD-ROM. 

25 Fig . 29B assumes a state in which the BD-ROM shown in 
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Fig.29A is loaded in a version 1.0 playback device. Since 
the playback device in Fig. 29B is version 1.0, when branching 
occurs, branch-target MOVIE objects are identified by 
referring to the version 1.0 Index Table out of the version 
5 1.0 and 1.1 Index Tables. 

Fig. 29C assumes a state in which the BD-ROM shown in 
Fig. 2 9A is loaded in a version 1.1 playback device. Since 
the playback device in Fig.29C is version 1.1, when branching 
occurs, branch-target MOVIE objects are identified by 

10 referring to the version 1.1 Index Table out of the version 
1.0 and 1.1 Index Tables. 

In order to perform the above processing, module 
manager 2 0 in a playback device according to embodiment 3 
performs processing based on the flowchart in Fig. 30. When 

15 a BD-ROM is loaded in the playback device, module manager 
20 acquires the version number in the device (step S45) , reads 
whichever of the plurality of Index Tables recorded on the 
BD-ROM matches the acquired version number, and holds the 
read Index Table (step S46) . Module manager 20 then performs 

20 the processing of steps SI to S42 while referring to the held 
Index Table. Description of the processing of steps Si to 
S42, being the same as that shown in embodiment 2, is omitted 
here . 

According the present embodiment as described above, 
25 it is possible to guarantee compatibility with past versions 
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of playback devices even when various versions of playback 
devices and BD-ROMs appear on the market, by choosing an Index 
Table that matches the version of the playback device and 
performing playback with reference to this Index Table. 

5 

Embodiment 4 

The present embodiment relates to enhancements when 
realizing similar menu controls to DVD on a BD-ROM. Fig. 31 
shows a menu hierarchy realized by a BD-ROM. The menu 

10 hierarchy in Fig. 31 is structured to place a TopMenu at the 
highest level, and to be able to select a subordinate 
TitleMenu, SubtitleMenu, and AudioMenu from the TopMenu . The 
arrows swl, sw2 and sw3 in Fig. 31 schematically show menu 
switching by button selection. The TopMenu disposes buttons 

15 for receiving which of an audio selection, a subtitle 
selection, and a Title selection to perform (buttons snl, 
sn2, sn3 in Fig. 31). 

The TitleMenu disposes buttons for receiving movie work 
selections, such as selection of a cinema version of a movie 

20 work (Title), a director's cut version, or a game version. 
The AudioMenu disposes buttons for receiving whether audio 
playback is to be in Japanese or English, and the SubtitleMenu 
disposes buttons for receiving whether subtitle display is 
to be in Japanese or English. 

25 MOVIE objects for operating menus having such a 



WO 2004/074976 



PCT/JP2004/002026 



hierarchy are shown in Fig. 32. 

A First Play object (FirstPlay OBJ) is a dynamic 
scenario describing a startup procedure when loading a BD-ROM 
in a playback device. The square boxes representing the 
5 FirstPlay object show commands for executing this setup 
procedure. The last command of the FirstPlay object is a 
branch command, the branch target being a TopMenu object. 

The TopMenu object (TOPMenu OBJ) is a dynamic scenario 
for controlling the behavior of the TopMenu. The TopMenu 

10 object is the object called when a user requests a menu call, 
and equates to the status-setting routine mentioned in 
embodiment 1. The square boxes representing the TopMenu 
object schematize individual commands that express this 
control procedure. Included in these commands are a command 

15 for changing a state of buttons in the TopMenu in response 
to operations from the user, and a branch command for 
branching in response to the activation of buttons. The 
branch command realizes menu switching from the TopMenu to 
the TitleMenu, from the TopMenu to the SubtitleMenu, and from 

20 the TopMenu to the AudioMenu. 

An AudioMenu object (AudioMenu OBJ) is a dynamic 
scenario for controlling the behavior of the AudioMenu. The 
square boxes structuring the AudioMenu object schematize 
individual commands that express this control procedure. 

25 Included in these commands is a command for changing a state 
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of buttons in the AudioMenu in response to operations from 
the user, and a command for updating SPRMs used in audio 
setting in response to the activation of buttons. 

A SubtitleMenu object ( SubtitleMenu OBJ) is a dynamic 
5 scenario for controlling the behavior of the SubtitleMenu. 
The square boxes structuring the SubtitleMenu object 
schematize individual commands that express this control 
procedure. Included in these commands is a command for 
changing a state of buttons in the SubtitleMenu in response 
10 to operations from the user, and a command for updating SPRMs 
used in audio setting in response to the activation of 
buttons . 

A TitleMenu object (TitleMenu OBJ) is a dynamic 
scenario for controlling the behavior of the TitleMenu. The 

15 TitleMenu object is the object called when a user requests 
a Title search, and equates to the dynamic scenario used for 
Title searching mentioned in embodiment 1. The square boxes 
structuring the TitleMenu object schematize individual 
commands that express this control procedure. Included in 

20 these commands are a command for changing a state of buttons 
in the TitleMenu in response to operations from the user, 
and a branch command for branching in response to the 
activation of buttons . The branch command realizes branching 
to individual Titles . 

25 Menu behavior such as that realized in DVD can be 
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realized by these MOVIE objects for use with menus. Thus 
concludes the description of MOVIE objects relating to menu 
controls . 

Enhancement of the Index Table in the present 
5 embodiment will now be described. A FirstPlay Index, a 
TOPMenu Index, an AudioMenu Index, a SubtitleMenu Index, and 
a TitleMenu Index are added to the Index Table in the present 
embodiment. As described in embodiment 1, these indexes are 
also referred to by dynamic scenarios relating to each of 

10 the three modes. 

The FirstPlay Index is referred to during BD-ROM 
startup. The filename of the FirstPlay object is described 
in this index. 

The TopMenu Index, AudioMenu Index, SubtitleMenu Index, 

15 and TitleMenu Index are referred to when user operations are 
conducted to directly call the AudioMenu, SubtitleMenu, and 
TitleMenu. A direct call by a user is conducted by the user 
depressing an Audio select key, a Subtitle select key, or 
a Title select key on a remote controller. 

20 Thus concludes the description of enhancements to MOVIE 

objects in the present embodiment. Enhancement of a playback 
device in the present embodiment will now be described. To 
operate MOVIE objects such as these, module manager 20 needs 
to perform the processing procedures shown in the Fig. 33 

25 flowchart. 
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In the present embodiment, module manager 20, which 
originally performs menu controls, performs branch controls 
using the processing procedures shown in Fig. 33. This 
flowchart differs in that step S50 has been inserted between 
5 steps S30 and S31. If YES in step S50, module manager 20 
performs the steps S51 to S54 processing and returns to step 
S4. Steps S51 to S54 involve the setting of a scenario for 
conducting menu controls as the current dynamic scenario. 
That is, if the branch target of the branch command is xxxMenu 

10 (step S50=YES) , module manager 20 suspends the current 
dynamic scenario i, saves SPRMs and variable x (step S52), 
retrieves a filename from the Index corresponding to the 
branch-target menu (step S52), sets the dynamic scenario of 
the retrieved filename as the current dynamic scenario i 

15 (step S53) , and returns the current mode to MOVIE mode (step 
S54) . After that module manager 20 proceeds to execute the 
current dynamic scenario. 

Since branching to dynamic scenarios for menu controls 
is realized in indirect referencing via the Indexes of the 

20 Index Table, it is possible according to the present 
embodiment as described above to branch to dynamic scenarios 
for use in menu controls, even when a menu key is depressed 
during execution of Java mode or Browser mode. Audio and 
Subtitle switching from a Java virtual machine and Browser 

25 mode is made possible, thus realizing Audio and Subtitle 
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switching similar to normal DVD even when playback is 
performed using a Java virtual machine or Browser mode. 

Embodiment 5 

5 Embodiment 5 relates to an enhancement for preventing 

any detrimental effects that may be exerted on other modes 
by data provided for MOVIE mode. Controls in MOVIE mode can 
be performed not only by MOVIE objects but also by commands 
(button commands) in interactive graphics streams 

10 multiplexed onto AVClips . 

Button commands are executed when buttons described by 
graphics streams are activated. Having button commands 
incorporated in AVClips is convenient in the description of 
playback controls for having a playback device execute 

15 specific processing according to timings at which individual 
frames of particular moving images appear on a screen; that 
is, playback controls synchronized closely with the moving 
image content. Also, since button commands are multiplexed 
on the actual AVClip, it is not necessary to store all of 

20 the button commands corresponding to the AVClip in memory, 
even when there are several hundred sections wanting to 
perform playback controls . Since button commands are read 
from a BD-ROM for every ACCESS UNIT together with video 
packets, it is preferable to have button commands 

25 corresponding to a moving-image section for current playback 
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reside in memory, and then to delete these button commands 
from memory when playback of this moving-image section and 
store button commands corresponding to the next moving-image 
section in memory . Since button commands are multiplexed onto 
5 AVClips, it is possible to reduce the installed memory to 
a minimum required amount, even when, for instance, there 
are several hundred button commands . 

When button commands are embedded in a stream, the 
problem arises of interference from dynamic scenarios in Java 

10 mode. For example, if button commands embedded in a stream 
are supplied to modules when executing playback controls in 
Java mode, Java mode dynamic scenarios and button commands 
end up being executed at the same time, inviting player errors . 
With the present embodiment, which resolves this problem, 

15 Playltems are provided with a filter specification function. 

Filter specification refers to distinguishing between 
playable and unplayable elementary streams multiplexed on 
an AVClip. 

Fig. 34 shows an internal structure of a Playltem 
20 pertaining to embodiment 5. "Playable_PID_entries" has been 
added in Fig. 34. The leader hpl in Fig. 34 highlights the 
structure of Playable__PID_entries . As revealed below, 
Playable_PID_entries enumerates PID elementary streams for 
playback. 

25 The following description relates to which playback 
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controls are realized by filter specifications in Playltems . 
Fig .35 shows the hierarchical structure of PLs in which 
playback controls are performed by Java objects. The MOVIE 
object at level 4 in Fig. 35 includes a command (PlayPL (PL#1) ) 
5 for having PL#1 played. Playltem#3 of the three Playltems 
#1, #2 and #3 structuring PL#1 includes Playable_J?ID_entries , 
meaning that filter specification is possible. 

The Java object at level 4 in Fig. 35 includes a command 
(PlayPL (PL#2 ) ) for having PL#2 played. Playltem#12 of the 
10 two Playltems structuring PL#2 includes 

Playable_PID_entries, meaning that filter specification is 
possible . 

Fig. 36 shows what filter specifications are performed 
by Playable__PID__entries in Playltems #3 and #12. In Fig. 36, 

15 ACCESS ONITs structuring an AVClip are shown at the bottom, 
and two Playltems #3 and #12 are shown at the top. One video 
stream, three audio streams, two presentation graphics 
streams, and one interactive graphics stream are multiplexed 
in the ACCESS UNITs . A "Video_PID" PID is appended to the 

20 video stream, "Audio_PID" PIDs are appended to the audio 
streams, "P . Graphics_PID" PIDs are appended to the 
presentation graphics streams, and >X I . Graphics_PID" PIDs are 
appended to the interactive graphics streams. Of the three 
audio streams, the one having "Audio_PIDl" appended is 

25 English audio (0:English), the one having "Audio_PID2" 
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appended is Japanese audio (1: Japanese) , and the one having 
"Audio_PID3" appended is Commentary audio (2 : Commentary ) . 
Of the two presentation graphics streams, the one having 
"P . Graphics_PIDl" appended is English audio (0:English), and 
5 the one having "P . Graphics_PID2" appended is Japanese audio 
( 1 : Japanese) . 

Playltems #3 and #12 at the top of Fig. 36 have different 
filter specifications. The enumeration of squares in 
Playltems #3 and #12 are the actual content of 

10 Playable_PID_entries, Playltem#3 being set to allow playback 
of the Video_PID video stream, the Audio_PIDl and Audio_PID2 
audio streams, the P . Graphics_PIDl and P . Graphics_PID2 
presentation graphics streams, and the I . Graphics_PID 
interactive graphics stream. Playltem#12 is set to allow 

15 playback of the Video_PID video stream, and the Audio_PID3 
audio stream. When playing Playltem#3, Playable_PID_entries 
in Playltem#3 are set to PID filter 4 in the playback device. 
As a result, PID filter 4 outputs the Video_PID video stream 
to video decoder 5, outputs the Audio_PIDl and Audio_PID2 

20 audio streams to audio decoder 7, and outputs the 
P . Graphics_PIDl and P . Graphics_PID2 presentation graphics 
streams as well as the I . Graphics_PID interactive graphics 
stream to graphics decoder 9. Since Playltem#3 is set so that 
all of the graphics streams are playable, playback of all 

25 of the graphics streams multiplexed on the AVClip is 
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possible . 

On the other hand, since Playltem#12 is set so that not 
all of the graphics streams are playable, controls using Java 
language are possible without there being interference from 
5 dynamic scenarios in Java mode. 

Fig. 37 shows possible playback outputs resulting from 
Playable_PID_entries in Playltems #3 and #12. Since playback 
of the Video_PID video stream, the Audio_PIDl and Audio_PID2 
audio streams, the P . Graphics_PIDl and P . Graphics__PID2 

10 presentation graphics streams, and the I . Graphics__PID 
interactive graphics stream is possible with Playltem#3, it 
is possible with playback using MOVIE objects to perform 
playback output of the video stream following the playback 
output of the Audio_PIDl audio stream (i.e. the narration 

15 "She' s a captive of her own lies' 7 in Fig. 37), the 
P . Graphics_PIDl presentation graphics stream (the Japanese 
subtitle " f& § # © -5 ^ Kl V> b tl tz ") , and the 

I.Graphics_PID interactive graphics stream (CONTINUE? #YES 
©NO) . 

20 Playltem#12 is set so that not all of the graphics 

streams are playable, making it possible to only perform 
playback output of two stream; namely, the Video_PID video 
stream and the Audio_PID3 audio stream. If the Java object 
instructing the playback of this Playltem draws a virtual 

25 studio (i.e. the room containing a camera, chair and light 
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in Fig .37) , the Java object for performing the drawing will 
receive no interference from commands included in the 
graphics streams. It is thus possible to realize Java-mode 
specific processing, while avoiding interference from 
5 commands included in graphics streams. The Audio_PID3 audio 
stream set to playable by Playltem#12 is a commentary by the 
movie director (i.e. the lines "I take my hat off to her 
outstanding acting ability") , and by having such commentary 
by the director played in the virtual studio, it is possible 

10 to create the atmosphere of a movie set. 

As a result of this Java object, it is possible to listen 
to the movie director's comments while playing movie scenes 
as background images in a room modeled on a movie studio. 

By recording this Title on a BD-ROM as a bonus track 

15 Title, the product value of the BD-ROM can be increased. Using 
the filter specification in a Playltem to record the bonus 
track Title on the BD-ROM brings about the following merits. 

The commentary of world-renown movie directors is of 
definite interest to movie buffs, and exists on currently 

20 available DVDs as something that increases the added value 
of the movie work. 

While being able to listen to the director' s commentary 
is the greatest attraction of this Title, playing movies 
scenes as background images also helps to increases Title's 

25 attractiveness. In other words, being able to listen to 
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behind-the-scenes talk relating to the movie production 
while viewing highlight scenes from the movie increases the 
aura of the commentary. The problem in this case becomes one 
of how to handle audio streams relating to the commentary. 
The orthodox approach would be to provide movie scenes that 
one wants to use as background images separately from the 
main feature, and to multiplex these with audio streams so 
as to create the bonus track. However, this approach means 
that movie scenes for use as background images need to be 
recorded on the BD-ROM separately from the main feature, 
increasing the number of recording items and creating 
capacity-related problems . 

Another possible method involves multiplexing audio 
streams for the commentary on video streams for the main 
feature together with audio streams used in the main feature. 
This allows scenes from the main feature to be uses as 
background images to the commentary, although the danger here 
is that the commentary data will also be heard when playing 
the main feature. As such, the filter specification in the 
Playltem structuring the main feature Title is set so that 
only the audio stream of the commentary is OFF and any 
remaining audio streams are ON. On the other hand, the filter 
specification in the Playltem structuring the bonus Title 
is set so that only the audio stream of the commentary is 
ON and any remaining audio streams are OFF. By doing this, 
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it is preferable to multiplex all audio streams relating to 
the main feature and commentary together on a single AVClip 
for recording on a BD-ROM. 

Since it is not necessary to create separate AvClips 
5 for the commentary and main feature (i.e. an AvClip only for 
audio streams of the main feature, and an AvClip only for 
audio streams of the commentary) , it is possible to reduce 
the number of AVClips for recording on a BD-ROM, and make 
authoring easier. 

10 Thus concludes the description of enhancements to a 

BD-ROM in embodiment 5 . An enhancement to a playback device 
in embodiment 5 will now be described. 

The processing performed by a playback device in 
embodiment 5 is realized by playback control engine 12 

15 executing the processing procedures in Fig. 38. 

Fig. 38 is a flowchart showing the execution procedures 
of a PLPlay function performed by playback control engine 
12. In this flowchart, PLx is the PL targeted for processing, 
Ply is the PI targeted for processing, and ACCESS UNITv is 

20 the ACCESS UNIT targeted for processing. This flowchart 
comprises the following procedures: setting the PL specified 
by an argument of the PLPlay function as PLx, reading PLx 
to memory (step S61), identifying the PI targeted for 
processing (steps S62 to S64), and reading the ACCESS UNIT 

25 structuring this PI (steps S65 to S76) . 
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Step S62 is a judgment as to whether there is a PI 
argument specification. If there is an argument 
specif ication, playback control engine 12 sets Ply to the 
argument specified PI, and sets PIz to the same argument 
5 specified PI (step S63) . PIz is the PI defining the end of 
the reading range. Both Ply and PIz are set to the argument 
specified PI because of it only being necessary to read this 
PI in the case of a PI being specified by an argument. 

If there is no argument specification, playback control 

10 engine 12 sets Ply to the head PI in PLx, and sets PIz to 
the last PI in PLx (step S64) . 

Steps S65 to S76 show the reading of an ACCESS UNIT 
structuring Ply, and a decoding procedure. This procedure 
involves setting Playable_PID_entries in Ply to PID filter 

15 4 (step S65) , setting ACCESS UNITv that includes the In-point 
video frame in Ply from the EP_map (step S66) , instructing 
BD-ROM drive 1 to read ACCESS UNITv (step S67), and then, 
after passing through the judgments of steps S68 to S69, 
instructing video decoder 5 to decode video frames included 

20 in ACCESS UNITv (step S7 0) , and setting ACCESS UNITv to the 
next ACCESS UNIT (step S71) . After that the processing of 
steps S67 to S71 is repeated for all of the ACCESS UNITs 
belonging to Ply. 

Step S68 is a judgment as to whether ACCESS UNITv 

25 includes the In-point video frame. If the In-point video 
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frame is included (step S68=YES), playback control engine 
12 instructs video decoder 5 to decode from the In-point video 
frame to the last video frame in ACCESS UNITv (step S72), 
and moves to step S70. 
5 Step S69 is a judgment as to whether ACCESS UNITv 

includes the Out-point video frame. If the Out-point video 
frame is included (step S69=YES) , playback control engine 
12 instructs video decoder 5 to decode from the head video 
frame to the Out-point video frame in ACCESS UNITv (step S73) 

10 and releases Playable_PID__entries in Ply from PID filter 4 
(step S74) . As a result, the filter specification by Ply is 
set to OFF . The step S75 judgment is then performed. Step 
S75, which is the final judgment in the flowchart, judges 
whether Ply is now PIz. Playback control engine 12 ends the 

15 flowchart if step S75 is YES, and sets Ply to the next PI 
if NO (step S76), before returning to step S65. After that 
the processing of steps S65 to S77 is repeated until judged 
YES at step S75. Thus concludes the description of the 
processing procedures performed by playback control engine 

20 12 . 

Since Playltems are provided with a filter 
specification that sets which of the plurality of elementary 
streams multiplexed in an AVClip are playable and which are 
unplayable, it is possible according to the present 
25 embodiment to avoid any effects exerted by button commands 
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in elementary streams multiplexed on AVClips as a result of 
dynamic scenarios in each mode choosing compatible Playltems . 
As such, Java module 17 no longer receives any interference 
from button commands, which contributes to the stable 
5 operation of the playback device. 

Embodiment 6 

The present embodiment relates to BD-ROM production 
processes. Fig. 3 9 is a flowchart showing BD-ROM production 
10 processes pertaining to embodiment 6. 

The BD-ROM production processes includes a material 
production process S101 for creating materials such as moving 
image records and audio records, an authoring process S102 
for generating an application format, and a pressing process 
15 S103 for creating the BD-ROM master and pressing/laminating 
to complete the BD-ROM. 

Of these processes, the authoring process targeting the 
BD-ROM comprises the processes of steps S104 to S109. 

Scenario editing process S104 is for converting an 
20 outline created in the planning stage into a format 
comprehensible to a playback device. The scenario editing 
result is created as BD-ROM scenarios. Also, multiplexing 
parameters are also created in the scenario editing so as 
to realize multiplexing. 
25 Once dynamic scenarios have been competed in the 
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processes, the resume_intension_f lag, menu_call_mask, 
Title_search_mask of each dynamic scenario is set in step 
S105. These settings are performed according to the effects 
of SPRMs exerted on playback controls by the dynamic 
5 scenarios. Detrimental effects resulting from menu calls and 
title searches during playback are prevented as a result of 
these settings. 

Material encoding process S106 is a task for 
respectively encoding video, audio and sub-video material 

10 to obtain video, and audio and graphics streams. 

In multiplexing process S107, video, audio, and 
graphics streams obtained as a result of the material 
encoding are inter leave -multiplexed, and the result is 
converted to a single digital stream. 

15 In formatting process S108, various types of 

information are created based on BD-ROM-oriented scenarios, 
and the scenarios and digital streams are adapted to a BD-ROM 
format . 

Emulation process S109 is for confirming whether the 
20 authoring result is correct. 

Because of being able to describe Java objects and 
Webpage objects using Java and markup languages, it is 
possible in the authoring processes described above to 
develop Java objects and Webpage objects using the same 
25 sensibility as that applied in the development of normal 
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computer-oriented software. Therefore, the present 
embodiment has the effect of increasing the efficiency of 
scenario creation . 

5 Remarks 

The above description by no means shows the 
implementation of all configurations of the present 
invention. Implementation of the present invention is still 
possible according to implementation of configurations that 

10 carry out the following modifications (A) , (B) , (C) , (D) , 
.... The inventions pertaining to the claims of the present 
application range from expanded disclosure to generalized 
disclosure of the plurality of embodiments disclosed above 
and the modified configurations thereof. The degree of 

15 expansion or generalization is based on the particular 
characteristics of technical standards in the technical 
field of the present invention at the time of application. 

However, since the inventions pertaining to the claims 
reflect the means for resolving technical issues relating 

20 to the prior art, the technical range of the inventions 
pertaining to the claims does not extend beyond the technical 
range recognized by those knowledgeable in the art with 
respect to resolving technical issues relating to the prior 
art. As such, the inventions pertaining to the claims of the 

25 present application possess a material correspondence with 
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the disclosures in the detailed description. 

(A) In all of the embodiments, an optical disk 
pertaining to the present invention is implemented as a 
5 BD-ROM. However, the optical disk of the present invention 
is characterized by the recorded dynamic scenarios and Index 
Table, and these characteristics are not dependent on the 
physical properties of a BD-ROM . Any form of recording media 
is applicable as long as there exists the capacity to record 

10 dynamic scenarios and Index Tables. For example, optical 
disks such as DVD-ROM, DVD-RAM, DVD-RW, DVD-R, DVD+RW, DVD+R, 
CD-R, CD-RW, and the like, and optical-magnetic disks such 
as PD, MO and the like are applicable. Semiconductor cards 
such a compact flash cards, PCM-CIA cards and the like are 

15 also applicable, as are (i) magnetic recording disks such 
as flexible disks, SuperDisk, Zip, Clik! and the like, and 
(ii) removable hard disk drives such as ORB, Jaz, SparQ, SyJet, 
EZFley, microdrive and the like. Furthermore, the recording 
medium may also be a built-in hard disk. 

20 Dynamic scenarios, Index Tables, and PlayList 

information may be recorded on a different recording medium 
to AVClips and stream management information. These may then 
be read in parallel and played as a single video edit. 

25 (B) Although the playback devices in all of the 
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embodiments output AVClips recorded on a BD-ROM to a TV after 
decoding, the playback device may be structured from only 
a BD-ROM drive , and the TV may be equipped with all of the 
other elements. In this case, the playback device and the 
5 TV can be incorporated into a home network connected using 
IEEE1394. Also, although the playback devices in the 
embodiments are of a type used after connecting to a 
television, integral display-playback devices are also 
applicable. Furthermore, the playback device may be only 

10 those parts of the playback devices of the embodiments that 
perform essential parts of the processing. Because these 
playback devices are all inventions disclosed in the 
specification of the present application, acts involving the 
manufacture of playback devices based on an internal 

15 structure of the playback devices shown in embodiments 1 to 
6 are implementations of the inventions disclosed in the 
specification of the present application. Acts that involve 
transferring (retail when cost is involved; a gift when no 
cost is involved) , lending, or importing of playback devices 

20 shown in embodiments 1 to 6 are also implementations of the 
present invention. Acts that involve approaching the general 
user about transfer, rental or the like by means of show-widow 
displays, catalogue solicitation, pamphlet distribution and 
the like are also implementations of these playback devices. 

25 
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(C) Because of the information processing by computer 
programs shown in the flowcharts of Figs .20-22, Fig. 28, 
Fig. 30, Fig. 33, and Figs. 38 being realized specifically 
using hardware resources, computer programs showing the 

5 processing procedures in the flowcharts form an invention 
in their own right. Although all of the embodiments show 
embodiments that relate to the implementation of computer 
programs pertaining to the present invention in an 
incorporated form in the playback devices, the computer 

10 programs shown in embodiments 1 to 6 may be implemented in 
their own right, separate from the playback devices. The 
implementation of the computer programs in there own right 
includes acts that involve: (1) production of the programs, 
(2) transference of the programs, either gratuitous or 

15 otherwise, (3) lending of the programs, (4) importing of the 
programs, (5) providing the programs publicly via 
bi-directional electronic communications circuits, and (6) 
approaching the general user about transfer, rental and the 
like by means of show-widow displays, catalogue solicitation, 

20 pamphlet distribution, and so forth. 

(D) Consider that the element of "time" relating to the 
steps executed in time-series in the flowcharts of Figs . 20-22 , 
Fig. 28, Fig. 30, Fig. 33, and Figs. 38 is a required item for 

25 specifying the invention. If this is the case, then the 
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processing procedures shown by the flowcharts can be 
understood as disclosing the usage configurations of the 
playback method. Execution of the processing in the 
flowcharts so as to achieve the original objects of the 
5 present invention and to enact the actions and effects by 
performing the processing of the steps in time-series is, 
needless to say, an implementation of the recording method 
pertaining to the present invention. 

(E) With embodiment 5, Menus (ChapterMenu) for 
10 displaying lists of Chapters and MOVIE objects for 

controlling the behavior of these Menus may be recorded on 
a BD-ROM, and branching enabled from the Top Menu . Also, these 
Menus may be called by the depressing of a Chapter key on 
a remote controller. 

15 

(F) When recording on a BD-ROM, extension headers 
preferably are appended to TS packets structuring AVClips . 
The extension headers, which are called TP_extra_header , 
include an "Arrival_Time_J3tamp" and a 

20 "copy_permission_indicator", and have a 4 -byte data length. 
TP_extra_header- attached TS packets (hereinafter, 
abbreviated to "EX-attached TS packet") are arranged into 
groups of 32 packets, and written into three sectors. Each 
group comprising 32 EX-attached TS packets is 6,144 bytes 

25 in length (=32x192), and matches the 6, 144-byte size of three 
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sectors (=2048 x3) . The grouping of 32 EX-attached TS packets 
contained in three sectors is referred to as an "Aligned 
Unit''. 

A playback device 200 transmits Aligned Units in 

5 transmission processing as described below, when used in a 
home network connected via IEEE1394. That is, a device on 
the side of the sender removes the TP_extra_header from each 
of the 32 EX-attached TS packets included in an Aligned Unit, 
and outputs the TS packets after encoding the TS packet body 

10 based on a DTCP standard. When outputting TS packets, 
isochronous packets are inserted between all adjacent TS 
packets. The positioning of isochronous packets is based on 
times shown in the Arrival_Time__Stamp in each 
TP_extra_header . Playback device 200 outputs a 

15 DTCP_Descriptor following the outputting of the TS packets. 
The DTCP_Descriptor shows a copy permissibility setting in 
each TP_extra_header . Here, if the DTCP_Descriptor is 
described so as to show "copy prohibited", TS packets will 
not be recorded on other devices when used in a home network 

20 connected via IEEE1394. 

(G) Although digital streams recorded on a recording 
medium in the embodiments are AVClips, the digital streams 
may be VOBs (Video Objects) complying with a DVD-Video 
25 standard or a DVD-Video Recording standard. VOBs are program 
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streams compliant with ISO/IEC13818-1 obtained by 
multiplexing video and audio streams. Also, video streams 
in AVClips may be MPEG-4 format, WMV format, or the like. 
Furthermore, audio streams may be a Linear-PCM format, 
5 Dolby-AC3 format, MP3 format, MPEG-AAC format, a Dts, or WMA 
(Windows media audio) . 

(H) In the structure of the playback devices, only the 
current dynamic scenario is stored in dynamic scenario memory 

10 15 and only current stream management information and current 
PL information is stored in the static scenario memory 11. 
However, a plurality of scenarios, stream management 
information and PL information may be stored in advance, as 
with cache memory. By doing this, the time lag until reading 

15 this data from the BD-ROM can be shortened. Also, although 
BACKUP memory 14 saves the stored values of registers in stack 
form, when consideration is given to the relationship with 
memory size, it is realistic to arrange the stored values 
for saving on the one level. 

20 

(I) Movie works in the embodiments may be obtained by 
encoding analog video signals broadcast by analog broadcast, 
or may be stream data constituted from transport streams 
broadcast by digital broadcast. 

25 Also, contents may be obtained by encoding 
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analog/digital video signals recorded on videotape. 
Furthermore , contents may be obtained by encoding 
analog/digital video signals taken directly from a video 
camera. Alternatively , the contents may be digital 
5 copyrighted works distributed from a distribution server. 

(J) Java module 17 may be a Java platform installed in 
a device in order to transmit satellite broadcasts. If Java 
module 17 is this Java platform, a playback device pertaining 
10 to the present invention shares processing as MHP-use STBs. 

Furthermore, Java module 17 may be a Java platform 
installed in a device in order to perform mobile telephone 
processing controls . If Java module 17 is this Java platform, 
a playback device pertaining to the present invention shares 
15 processing as a mobile telephone. 

Also, BROWSER module 18 may be computer-installed 
Browser software such as Microsoft's Internet Explorer, and 
the like. 

20 (K) In the layer model shown in the drawings, Browser 

mode and MOVIE mode may be disposed over Java mode. 
Particularly because of the light burden on the playback 
device of the execution of control procedures based on 
dynamic scenarios, the interpretation of dynamic scenarios 

25 in MOVIE mode, and the like, no problems arise even when MOVIE 
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mode is executed over Java mode. Also, when developing 
playback devices and movie works, operation assurance can 
be dealt with in a single mode. 

Furthermore, Java mode processing may be executed only 
in Java mode, without providing three modes. As shown in 
embodiment 2, since playback controls synchronized with PL 
playback are possible even in Java mode, the necessity of 
providing MOVIE mode is removed. Furthermore, controls in 
dynamic scenario may be only MOVIE mode or only Browser mode. 

INDUSTRIAL APPLICABILITY 

Recording media and playback devices pertaining to the 
present invention are capable of imparting interactive 
controls on movie works, thus making it possible to supply 
the market with movie works having high added value and to 
invigorate the markets for movies, consumer appliances, and 
the like. As such, recording media and playback devices 
pertaining to the present invention are highly applicable 
in the movie and consumer appliance industries. 
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CLAIMS 

1 . A recording medium having video data and a dynamic scenario 
recorded thereon, wherein 

the dynamic scenario is a command string showing a 
playback control procedure of the video data, and has 
attribute information appended thereto, 

the attribute information shows a control procedure for 
when a user requests a menu call during playback of the video 
data, and includes a first flag, and 

the first flag indicates, when the menu call ends during 
playback of the video data, whether to resume playback of 
the video data from a playback position at a time that the 
menu call was requested. 

2. The recording medium of claim 1, wherein 

plural pieces of video data are recorded thereon, 
the playback control procedure shown by the dynamic 

scenario is a control for conditionally playing one of the 

pieces of video data, 

the condition is defined using a system parameter, and 
the menu call calls processing to change the system 

parameter . 

3. The recording medium of claim 2, wherein 

the system parameter is a value showing one of a 
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language setting in a playback device, an audio setting in 
a playback device, a sub-video setting in a playback device, 
and an angle setting in a playback device. 

4. The recording medium of claim 1, wherein 

the attribute information includes a second flag, 
the second flag indicates, when the user requests the 

menu call during playback of the video data, whether to mask 

the request, and 

the first flag is valid when the second flag is OFF. 

5. The recording medium of claim 4, wherein 

a pairing of the dynamic scenario and the video data 
constitutes a title in the recording medium, 

a plurality of titles is recorded thereon, 
the attribute information includes a third flag, 
the third flag indicates, when the user requests a title 
search during playback of video data by a dynamic scenario, 
whether to mask the request, and 

the first flag is valid, even when the third flag is 

ON. 

6. The recording medium of claim 1, wherein 

the dynamic scenario includes a branch command, 
types of the dynamic scenario include one or more 
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dynamic scenarios for a movie mode and one or more dynamic 
scenarios for an enhanced mode, 

the branch command specifies a branch target by 
indirect referencing via a table, 
5 the table includes a plurality of indexes corresponding 

one-to-one with a plurality of dynamic scenarios for 
targeting as branch targets, and an index for exception 
processing, 

the exception processing is performed when branching 
10 to an unexecutable enhanced-mode dynamic scenario is 
instructed, and 

the exception processing index corresponds to a 
movie-mode dynamic scenario that replaces the unexecutable 
enhanced-mode dynamic scenario. 

15 

7. The recording medium of claim 1, wherein 

the dynamic scenario includes a branch command, 
types of the dynamic scenario include one or more 

dynamic scenarios for a movie mode and one or more dynamic 
20 scenarios for an enhanced mode, 

the branch command specifies a branch target by 

indirect referencing via a table, 

a plurality of the tables corresponding one-to-one with 

plural versions of a data format is recorded thereon, 
25 the versions of the data format include a first version 
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corresponding only to the movie mode, and a second version 
corresponding to the movie mode and the enhanced mode, 

information relating to the one or more movie-mode 
dynamic scenarios is described in the table corresponding 
5 to the first version, and 

information relating to the one or more movie-mode and 
enhanced-mode dynamic scenarios is described in the table 
corresponding to the second version. 

10 8. The recording medium of claim 1, wherein 

plural pieces of playback section information are 
recorded thereon, 

each piece of playback section information shows a 
playback start point and a playback end point in the video 
15 data, and 

the playback control procedure in the dynamic scenario 
instructs a playback device to perform playback using one 
of the pieces of playback section information. 

20 9. The recording medium of claim 8, wherein 

a video stream constitutes a multiplexed stream having 
a plurality of elementary streams multiplexed thereon, 

each piece of playback section information shows a 
filter specification of each elementary stream in 
25 correspondence with the playback start and end points in the 
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video data, and 

the filter specification specifies for each 
multiplexed elementary stream, whether the elementary stream 
is playable. 

10, A playback device relating to a recording medium having 
video data and a dynamic scenario recorded thereon, 
comprising : 

a module operable to interpret a playback control 
procedure shown in the dynamic scenario; 

a playback unit operable to playback the video data in 
accordance with the interpretation by the module; 

a reception unit operable to receive a user operation 
during playback of the video data; and 

a manager operable to execute a control procedure shown 
in attribute information appended to the dynamic scenario 
if the received user operation is a menu call request, wherein 

the attribute information includes a first flag, 

the control procedure executed by the manager when the 
first flag is ON is a control for executing the menu call 
after stopping playback of the video data, and resuming 
playback of the video data from a playback position at a time 
of the menu call request after the menu call has ended, and 

the control procedure executed by the manager when the 
first flag is OFF is a control for not resuming playback of 
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the video data after the menu call has ended. 

11. The playback device of claim 10, comprising a memory and 
a register set that stores a system parameter showing a 

5 playback time of the video data, wherein 

resuming playback of the video data is realized by 
processing to save the system parameter stored in the 
register set in the memory when playback of the video data 
is stopped, and processing to restore the system parameter 
10 saved in the memory to the register set when the memory call 
has ended. 

12. The playback device of claim 11, wherein 

the control procedure executed by the manager when the 
15 first flag is OFF is a control for restarting the video data 
after execution of the menu call, and 

restarting the video data is realized by processing for 
initializing the system parameter stored in the register set 
when playback is stopped and saving the initialized system 
20 parameter in the memory, and processing to restore the system 
parameter saved in the memory to the register set when the 
memory call has ended. 

13. The playback device of claim 10, wherein 

25 the playback control procedure shown in the dynamic 
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scenario is a control for conditionally playing one of plural 

pieces of video data, 

the condition is defined using a system parameter, and 
the playback device comprises a register set that 
5 stores the system parameter showing one of a language setting 

in the playback device, an audio setting in the playback 

device, a sub-video setting in the playback device, and an 

angle setting in the playback device. 

10 14. The playback device of claim 10, wherein 

the attribute information includes a second flag, 
the manager masks the menu call request by the user 

during playback of the video data when the second flag is 

ON, and 

15 menu call execution by the manager is performed when 

the second flag is OFF and the user request the menu call. 

15. The playback device of claim 14, wherein 

a pairing of the dynamic scenario and the video data 
20 constitutes a title in the recording medium, 

a plurality of titles is recorded on the recording 

medium, 

the attribute information includes a third flag, 
the manager masks a title search request made by the 
25 user during playback of the video data when the third flag 
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is ON, and 

menu call execution by the manager is performed, even 
when the third flag is ON. 

5 16. The playback device of claim 10, wherein 

the dynamic scenario includes a branch command, 
types of the dynamic scenario include one or more 

dynamic scenarios for a movie mode and one or more dynamic 

scenarios for an enhanced mode, 
10 the branch command specifies a branch target by 

indirect referencing via a table, 

types of the module include a module corresponding to 

the movie mode, and a module corresponding to the enhanced 

mode, and 

15 if dynamic-scenario execution by the enhanced-mode 

module is not possible, the manager has the movie-mode module 
execute a movie-mode dynamic scenario for exception 
processing shown in the table, even when a label specifying 
a branch-target dynamic scenario is allocated to an index 

20 belonging to the enhanced mode. 

17. The playback device of claim 10, wherein 

the dynamic scenario includes a branch command, 
types of the dynamic scenario include one or more 
25 dynamic scenarios for a movie mode and one or more dynamic 
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scenarios for an enhanced mode, 

the branch command specifies a branch target by 
indirect referencing via a table, 

a plurality of the tables corresponding one-to-one with 
5 plural versions of a data format is recorded on the recording 
medium, 

the versions of the data format include a first version 
corresponding only to the movie mode, and a second version 
corresponding to the movie mode and the enhanced mode, 
10 types of the module include a module corresponding to 

the movie mode, and a module corresponding to the enhanced 
mode, and 

the manager identifies a dynamic scenario to be a branch 
target from the table corresponding to the version of the 
15 playback device out of the tables for the versions recorded 
in the recording medium, and has the module corresponding 
to a mode of the branch-target dynamic scenario execute the 
dynamic scenario. 

20 18. The playback device of claim 10, wherein 

the video data is multiplexed with a plurality of 
elementary streams, and recorded on the recording medium as 
a multiplexed stream together with playback section 
information, 

25 each piece of playback section information shows a 
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filter specification of each elementary stream in 
correspondence with a playback start point and a playback 
end point of the video data, 

the playback device comprises: 
5 a reading unit operable to read from an access unit, 

in the multiplexed stream, to which the playback start point 
belongs until an access unit to which the playback end point 
belongs ; 

a separation unit operable, when access units are read, 
10 to separate a part of each elementary stream multiplexed to 
the access unit; and 

a plurality of decode units operable to decode the 
separated part of the elementary streams, 

the playback section information includes information 
15 showing a filter specification in a playback section, and 

the elementary streams processed by the separation unit 
are pieces of information shown in the filter specification 
information to be playable. 

20 19. The playback device of claim 10, wherein 

types of the module include a module corresponding to 
a movie mode, and a module corresponding to an enhanced mode, 
and 

the reception unit includes a dispatcher operable to 
25 perform processing so that during execution of the dynamic 
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scenario by the enhanced-mode module , a predetermined user 
operation is not sent to the enhanced-mode module. 

20. The playback device of claim 19, wherein 
5 the processing performed by the dispatcher so as not 

to send the predetermined user operation to the enhanced-mode 
module is one of an up/down/left /right arrow key and an 
activate key. 

10 21. A recording method, comprising the steps of: 
creating application data; and 

recording the created application data on a recording 
medium, wherein 

the application data includes video data and a dynamic 
15 scenario, 

the dynamic scenario is a command string showing a 
playback control procedure of the video data, and has 
attribute information appended thereto, 

the attribute information shows a control procedure for 
20 when a user requests a menu call during playback of the video 
data, and includes a first flag, and 

the first flag indicates, when the menu call ends during 
playback of the video data, whether to resume playback of 
the video data from a playback position at a time that the 
25 menu call was requested. 
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22 . A computer program for having a computer play a recording 
medium that has a dynamic scenario and video data recorded 
thereon, the program having the computer execute the steps 
5 of: 

interpreting a playback control procedure shown in the 
dynamic scenario; 

playing the video data in accordance with a result -of 
the interpretation; 
10 receiving a user operation during playback of the video 

data; and 

executing a control procedure shown in attribute 
information appended to the dynamic scenario if the received 
user operation is a menu call request, wherein 
15 the attribute information includes a first flag, 

the control procedure executed by the manager when the 
first flag is ON is a control for executing the menu call 
after stopping playback of the video data, and resuming 
playback of the video data from a playback position at a time 
20 of the menu call request after the menu call has ended, and 
the control procedure executed by the manager when the 
first flag is OFF is a control for not resuming playback of 
the video data after the menu call has ended. 

25 23. A playback method relating to a recording medium having 
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a dynamic scenario and video data recorded thereon, 
comprising the steps of: 

interpreting a playback control procedure shown in the 
dynamic scenario; 
5 playing the video data in accordance with a result of 

the interpretation; 

receiving a user operation during playback of the video 
data; and 

executing a control procedure shown in attribute 
10 information appended to the dynamic scenario if the received 
user operation is a menu call request, wherein 

the attribute information includes a first flag, 
the control procedure executed by the manager when the 
first flag is ON is a control for executing the menu call 
15 after stopping playback of the video data, and resuming 
playback of the video data from a playback position at a time 
of the menu call request after the menu call has ended, and 
the control procedure executed by the manager when the 
first flag is OFF is a control for not resuming playback of 
20 the video data after the menu call has ended. 
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FIG. 1A 

DYNAMIC SCENARIO 



function{PlayPL(PL#1 ,PI#1 ) 
if (SPRM(0)==" Japanese") { 
PlayPL(PL#4,PI#1 ); 

}6lSG{ 

PlayPL(PL#2,PI#1);} 
PlayPL(PL#3,PI#1); 
} 

} 
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FIG. 14A 



MovieObject(l ){ 
resume_intension_flag=0 
menu_call_mask=0 
Title_search_mask=0 
function{PlayPL(PL#l ,PI#1 ) 
if(SPRM(0)=="Japanese"){ 
PlayPL(PL#4,PI#1 ); 
}else{ 

PlayPL(PL#2,PI#1);} 
PlayPL(PL#3,PI#1); 
} 

} 
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FIG. 1 5A 

PLAYBACK DEVICE REGISTER 



PARAMETERS 
RELATING TO H 
CURRENT PLAY- 
BACK POSITION 



SPRM (0) 



SPRM (1) 



SPRM (2) 



SPRM (3) 



SPRM (4) 



SPRM (5) 



SPRM (6) 



SPRM (7) 



SPRM (8) 



SPRM (31) 



INITIALIZE 



FIG. 1 5B 



PLAYBACK DEVICE REGISTER 



STATUS-SETTING 



SPRM (0) 



SPRM (1) 



SPRM (2) 



SPRM (3) 



SPRM (4) 



SPRM (5) 



SPRM (6) 



SPRM (7) 



SPRM (8) 



SPRM (31) 



WHEN STATUS-SETTING 
ROUTINE CALLED 



MEMORY 




FIG. 1 5C 



SPRM (4) 



SPRM (5) 



SPRM (6) 



SPRM (7) 



SPRM (8) 



PLAYBACK DEVICE REGISTER 



MEMORY 



SPRM (0) 



SPRM (1) 



SPRM (2) 



SPRM (3) 



SPRM (4) 



SPRM (5) 



SPRM (6) 
SPRM (7) 
SPRM (8) 



WHEN STATUS-SETTING 
ROUTINE ENDED 




SPRM (4) 



SPRM (5) 



SPRM (6) 



SPRM (7) 



SPRM (8) 



SPRM (31) 



15/39 



WO 2004/074976 PCT/JP2004/002026 



FIG. 1 6A 



MovieObject(1 ){ 
resume_intension_f lag= 1 
menu_call_mask=0 
Title_search_mask=0 
function {PlayPL(PL#l ,PI#1 ) 
if(GPRM(0)=="Answer1 "){ 
PlayPL(PL#4,PI#1 ); 
}else{ 

PlayPL(PL#2,PI#1 );} 
PlayPL(PL#3,PI#l ); 
} 

} 
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MovieObjectO ){ 
resume_intension_flag=0 
menu_call_mask=0 
Title_search_mask=0 
function{PlayPL(PL#4,PI#1 ) 
PlayPL(PL#1 ,PI#1 ); 
if(SPRM(13)=="kids n ){ 
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} 



FIG. 17B 



FIG. 17C 



PLAYBACK 
POSITION 



Pc2 



Pel 



for adults 



PlayList#4 




PlayList#1 


L— > 








PlayList#2 [ 



for kids 
PlayList#4 



T 



PLAYBACK 
POSITION 




STATUS-SETTING ROUTINE 



kids-+Adult 



Pel 



Pc2 




for adults 



PlayList#4| ^ PlayList#1 M — > | PlayList#2 | j PlayList#3 | 



for kids 
PlayList#4 




1 7/39 



WO 2004/074976 



PCT/JP2004/002026 



CO 
GO 

Li 

CO 



ooo 

J8 £ 

rr— CO CO 





CD 



18/39 



WO 2004/074976 



PCT/JP2004/002026 




19/39 



WO 2004/074976 



PCT/JP2004/002026 



FIG. 20 



( START ) 



v 



RETRIEVE FILENAME FROM FIRST 
PLAY INDEX IN INDEX TABLE 



CURRENT MODE«-MOVIE MODE 



v 



CURRENT 
DYNAMIC 
SCENARIO i 



DYNAMIC SCENAR- 
IO OF RETRIEVD FI- 
LENAME 



-SI 

-S2 
S3 



<5> 



READ CURRENT DYNAMIC 
SCENARIO i TO MEMORY 



S4 



INITIALIZE X h "S5 



S6 



v 



HAVE MODULE OF CURRENT MODE EXECUTE 
COMMAND x IN CURRENT DYNAMIC SCENARIO i 



d> 




COMMAND x "-NEXT COMMAND 



20/39 



PCT7JP2004/002026 




WO 2004/074976 



PCT/JP2004/002026 




WO 2004/074976 



PCT/JP2004/002026 



CO 

CO 
CNJ 

cj3 




X 













X 


X 








X 

LU 


LLJ 


X 

LU 




X 

LU 


LU 

Q 


LU 

Q 




X 

LU 


X 
LU 


Q 


Q 


Q 




Q 








Q 


Q 
























CO 


CO 


• • • 


E 


+ 


+ 






O 




*fc 


*fc 




% 


E 


E 


• • • 




*fc 


LU 


LU 


LU 




LU 
—1 


LU 


LU 




LU 


LU 


— 1 


[ 


— 1 






—I 


-J 


H 


h- 


h- 




111 


1 


—1 




H 




H 

si 1 


1- 




111 


111 




h- 


H 



77 



\ 



< 

CO 
CM 



Q 
CQ 



23/39 



WO 2004/074976 



PCT/JP2004/002026 




INDIRECT 
REFERENCE 
Index Table TABLE 



/ CONTROL PROCEDURES \ 

om mox/ifI DESCRIBED USING DVD 
UU I -MUVIh \\ L|KE COMMANDS 



002.MOVIE 



( - 003. MOVIE 



HoQ4.mqvie| 
h info.bd~k ^ 



cjclass: 



CONTROL PROCEDURES 
00 1 .CLASS |( DESCRIBED USING JAVA 
LANGUAGE 



Title#1 Index 



Title#2lndex 



Title#3lndex 



Title#4lndex 



Title#mlndex 



Title#m+1 1 1ndex 



Title#m+21 Index 



Title#m+31 Index 



Title#m+41 Index 



Title#nlndex 



Title#Olndex 



002. CLASS 



«- 003. CLASS 



004.CLASSI 



FIG. 24B 



Title#1 Index 
Title#2lndex 
Title#3 Index 
Title#4lndex 



Title#mlndex 
Title#m+1 Index 
Title#m+2lndex 
Title#m+3lndex 
Title#m+4lndex 



Title#nlndex 
Title#Olndex 



Index Table 



FILENAME TO0 1 -MOVIE I 



FILENAME r002.M0VIE_l 



FILENAME r003.MOVIE l 



FILENAME r004.MQVIEJ 



FILENAME fOOLCLASSJ 



FILENAME r002. CLASS I 
FILENAME r003. CLASS] 
FILENAME r004.CLASSJ 



FILENAME fOOO-MOVIE I 



m: BOUNDARY VALUE 
OF MODE 

y MOVIE MODE 



JAVA MODE 
(ENHANCED MODE) 



24/39 



WO 2004/074976 



PCT/JP2004/002026 



FIG. 25A 

MOVIE MODE + JAVA MODE POSSIBLE (FULL SYSTEM) 



Jmp Title#1 
Jmp Title#2 
Jmp Title#3 
Jmp Title#4 



Jmp Title#m 
Jmp Title#m+1 - 
Jmp Title#m+2- 
Jmp Title#m+3- 
Jmp Title#m+4- 

Jmp Title#n 




Index Table 



Title#1 Index 



Title#2lndex 



Title#3 Index 



Title#4lndex 



Title#mlndex 



Title#m+1 Index 



Title#m+2lndex 



Title#m+3lndex 



Title#m+4lndex 



Title#nlndex 



Title#Olndex 



READ 001. MOVIE 
READ 002.MOVIE 
READ 003. MOVIE 
READ 004.MOVIE 



READ 001 .CLASS 
READ 002. CLASS 
READ 003. CLASS 
READ 004.CLASS 



FIG. 25B 

ONLY MOVIE MODE POSSIBLE (CORE SYSTEM) 




Jmp Title#1 
Jmp Title#2 
Jmp Title#3 
Jmp Title#4 



Jmp Title#m 
JmpTitle#m+1 
Jmp Title#m+2-7^f 
JmpTitle#m+3 
Jmp Title#m+4 




Index Table 



Title#1 Index 



Title#2lndex 



Title#3lndex 



Title#4lndex 



Title#mlndex 



Title#Olndex 



READ 001. MOVIE 
READ 002.MOVIE 
READ 003.MOVIE 
READ 004.M0VIE 



READ 000.MOVIE 



Jmp Title#n 



25/39 



WO 2004/074976 



PCT/JP2004/002026 



C\J 




CO 

£ 

X 

LU 

Q 













X 


X 








X 

LU 


X 

LU 


X 

LU 




X 
LU 


LU 

Q 


LU 

Q 




X 

LU 


X 
LU 


Q 


Q 


Q 




Q 








Q 


Q 














CNJ 










C\J 


CO 


• • a 


E 


+ 


+ 






O 


% 

LU 


LU 


LU 




LU 


E 


E 




LU 


*fc 
LU 


ITL 


ITL 


ITL 




-J 
h- 


LU 
-J 


LU 
1 




-J 


-J 
h- 




h- 


I— 








111 











<§)<§>© 



26/39 



WO 2004/074976 



PCT/JP2004/002026 



CO 

< 



Q 

(XI 




CD 



INDEX 


INDEX 


INDEX 






C\J 


CO 


• • 


ITLE 


ITLE 


TLE 




h- 


I— 











ft 

LU 
_l 



3* 



+ 
E 





X 


LU 


LU 


Q 


Q 








O 




% 


LU 
1 


LU 
-J 


111 


111 




o 
h- 
< 

O 
u_ 

Dl 
_l 
O 



O 
> 





< CQ U 

or rr rv 

l±! 1^ l±! 

C-> CJ> o 

i i ^ 

I I £ 

cj> ej> <lj> 

LU LU LU 

CO CO CO 

o o o 

o o o 

5 5 5 



CO 
CO 

n: 

< 



27/39 



WO 2004/074976 



PCT/JP2004/002026 




28/39 



WO 2004/074976 



PCT/JP2004/002026 




DEX 1 


DEX 


DEX 




DEX 


INDEX | 


INDEX 




X 

LU 

Q 


X 

LU 

Q 




z; 
















CVl 

=8: 


CO 


• • 


E 

=9: 


+ 


+ 


• • 






TITLE 


TITLE 


TITLE 




TITLE 


TITLE 


TITLE 




TITLE 


TITLE 



OQ 
CD 
CVl 

e5 



uj O 
_J ■ 

j<.2 

UJ ^ 
2 o 




X 


X 


X 

LU 




X 


LU 


LU 




LU 


Q 


Q 


Q 






~Z. 




21 








OJ 


CO 


• • 




*fc 








=i 


LU 
-J 


UJ 
1 


LU 
1 




LU 

I 


h» 


1— 


h- 




1111 


h- 


h- 








X 


X 


X 




LU 


LU 


LU 




Q 


Q 


Q 




Z; 










CM 


CO 


• • 


=tfc 


=tt 




LU 
-J 


LU 
—1 


LU 
-J 




H 


1— 


h- 






h" 


H 








o 

Of 

Q 



29/39 



WO 2004/074976 



PCT/JP2004/002026 



FIG. 30 

(start) 

acquire version no. in device | — s45 



READ INDEX TABLE MATCHING ACQUIRED VERSION NO. 
FROM INDEX TABLES RECORDED ON BD-ROM, AND HAVE 
MODULE MANAGER HOLD READ INDEX TABLE 



RETRIEVE FILENAME FROM FIRST PLAY 
INDEX IN INDEX TABLE 



-ST 



CURRENT MOPE<-MOVIE MODE | — S2 



CURRENT DYNAMIC 
SCENARIO i 



DYNAMIC SCENARIO OF 
RETRIEVED FILENAME 



-S46 



S3 



READ CURRENT DYNAMIC SCENARIO i TO MEMORY] — S4 



INITIALIZE X| — S5 



S6 



HAVE MODULE OF CURRENT MODE EXECUTE 
COMMAND x IN CURRENT DYNAMIC SCENARIO i 




YES 



hKw) 



NO * 



-© 



v 



COMMAND x <-NEXT COMMAND K S9 



30/39 



WO 2004/074976 



FIG. 31 



PCT/JP2004/002026 




31/39 



WO 2004/074976 



PCT/JP2004/002026 




32/39 



WO 2004/074976 



PCT/JP2004/002026 



°3 



00^ > 
CO 2 CO 



-3> 



1 








CJ> 


1 


S3 


L_U 




CD 




<c 


;from 


ANCH1 


^: 


CO 


U-l 


TO] 


— i 


CD 

2: 


LU 

> 


Q 


L_U 


o 


Q_ 


1 GO 




■ i i 



i u- 

O |_U 

oo ^ 
or: S < 

2 Z H 

LU LU == 

CO CO Q 
OO lu 

^^LU 

:z: ^ i — 
>— Lu 

Q Q a: 



/LO 

CO 



cj> | 

25§ 



CO 
CO 



o 
co 




00 
CO 
CO 




V 

co 

LU 

o 
h- 



33/39 



WO 2004/074976 



PCT/JP2004/002026 




34/39 



WO 2004/074976 



PCT/JP2004/002026 




WO 2004/074976 



PCT/JP2004/002026 



aid so!udej9-| 


1 

n 

teracive 
raphics 

1 — I 




1 1 

■esentatio 
graphics 

In 

g 


(qs!|6u3:o) Laid~SDmdBJ9-d 


/(XjBiU9luCu63:2)£cild~'o!pnv 0 

J r j' >' >< S jr S ,r ,r jf ,r f 


0 

Z5 
< 


/X/(as9UBder:L)zaid o|pnv / 


/VV/^silBugroJiaid ojpny/ 




Video 


/ aid _ S3!LjdBJ9-| 


ill 


y ^brfueue| . LJcUld soiLjaBJy d 


'esentatio 
graphics 

In 

g 


Vi (MS!|Bu3:o)Laid~SDmdBJ9-d 


' V(X/Biuakiuj63:2)£aid~'o!pnV/ 


CL. 

O 
< 


y r y f f 6 jf J ' jr , jr '\ jr jf jf jf > f > e j 

\ > 77 (asauBdef: Ozaid oipnv / 


L/yV/(MS!|6u3:o) Laid oipnv/ 


K\\\\\\X-aid-oep!A^ 


Video 


aid~SD!L|dBJ9-| 


c _S 2 J 




'esentatio 
graphics 

in 

g 


(L|S!|6u3:o) Laid'soiLjdejg-d 


y ( X/bju elu luo n : 7 ) p h ih~"o 1 p n v 0 


CL. 

O 

3 
< 


i' j' 1/ >' y y y y ■)'' 1' y y y y - 

^//(asauBder: 1 )zgid ojpny ' 


///yiS\^\xt-d) Lafd^ofpriv > 


X\\\\\\\\a,d-00P!A^ 


O ' 
CD 



CO 
CO 
LU 

u 
u 

< 



CO 
CO 
LU 

CJ 

< 



LU 

CJ 
CJ 

< 



36/39 



WO 2004/074976 



PCT/JP2004/002026 




37/39 



WO 2004/074976 



PCT/JP2004/002026 



FIG. 3 8 

(PLPLAY FUNCTION EXECUTION PROCEDURES) 



PLx+-PL SPECIFIED BY ARGUMENT 
READ PLx TO MEMORY 



-S61 



S62 



S64 



ARGU- 
MENT SPECIFICATION RELATING TO 
J?. 

'no 



YES 



HEAD PI OF Plx 
-LAST PI OF Plx 





S63 








Ply— PI SPECIFIED BY ARGUMENT 




PIz-PI SPECIFIED BY ARGUMENT 



SET Playable_PID_entries OF L, 
Ply IN PIP FILTER \ 



S65 



IDENTIFY ACCESS UNIT v INCLUDING In- I 
POINT VIDEO FRAME OF Ply FROM EP_map \ 



S66 



INSTRUCT DRIVE TO READ ACCESS UNITv~| ^S67 



S68. 



S69 



CESS UNIT v IN- 
CLUDES In-POINT VIDEO 
FRAME? 



"AC 7 " 

CESS UNIT v INCLUDES" 
Out-POINT VIDEO 
TRAME? 



YES 



S72 



INSTRUCT AV DECODER 
TO DECODE FROM In-POINT 
VIDEO FRAME 



YES 



S70, 



S71 



NO 



INSTRUCT AV DECODER TO 
DECODE VIDEO FRAMES 
INCLUDED IN ACCESS UNIT v 



1 



S73 



INSTRUCT AV DECOD- 
ER TO DECODE UNTIL 
Out-POINT VIDEO 
FRAME OF Ply 



S74 



ACCESS UNITv«-NEXT ACCESS UNIT | 



RELEASE Playable_PID_entries 
OF Ply FROM PID FILTER 



YES 



C ^D ) 
38/39 




WO 2004/074976 



PCT/JP2004/002026 



FIG. 39 



S101 



( START 



MATERIAL PRODUCTION PROCESS 



S102 



AUTHORING PROCESS 
(APPLICATION FORMAT 
CREATION) 



SI 03, 



PRESSING PROCESS | 



( END 3 



,S104 



(1 ) SCENARIO EDITING: DESCRIPTION 
OF DYNAMIC SCENARIO USING PLAY- 
ER-ORIENTED COMMANDS, JAVA 
LANGUAGE, MARKUP LANGUAGE 



SI 05 



SET resume_intension_flag, 
menu_call_mask, Title_- 
searchjmask OF DYNAMIC 
SCENARIO DEPENDING ON 
WHETHER PLAYBACK CON- 
TROL IS EFFECTED BY SPRM 



,S106 



(2) MATERIAL ENCODING | 



(3) MULTIPLEXING 




3 



S107 



(4) FORMATTING 



,S108 



SI 09 



(5) 



EMULATION 

V 



39/39 



